First commit
This commit is contained in:
55
app.js
Normal file
55
app.js
Normal file
@@ -0,0 +1,55 @@
|
||||
var createError = require('http-errors');
|
||||
var express = require('express');
|
||||
var logger = require('morgan');
|
||||
var cors = require('cors'); // Import du middleware CORS
|
||||
var indexRouter = require('./routes/index');
|
||||
var app = express();
|
||||
app.use(logger('dev'));
|
||||
app.use(express.json());
|
||||
|
||||
// ==========================================================
|
||||
// DÉMONSTRATION A02 : MAUVAISE CONFIGURATION CORS
|
||||
// ==========================================================
|
||||
|
||||
// --- OPTION 1 : la Vulnérabilité (A02) ---
|
||||
// '*' signifie que N'IMPORTE QUEL site web sur Internet
|
||||
// peut appeler votre API depuis le navigateur d'un client.
|
||||
const corsOptions_VULNERABLE = {
|
||||
origin: '*'
|
||||
};
|
||||
|
||||
// --- OPTION 2 : la correction ---
|
||||
// On n'autorise QUE notre front-end (penser à mettre le bon port lu après exécution de la page HTML frontend)
|
||||
const corsOptions_SECURISEE = {
|
||||
origin: 'http://localhost:5500' // ou 'http://127.0.0.1:5500'
|
||||
};
|
||||
|
||||
|
||||
// DÉCOMMANDEZ L'OPTION QUE VOUS VOULEZ TESTER :
|
||||
//
|
||||
app.use(cors(corsOptions_VULNERABLE)); // <--- Testez d'abord ceci
|
||||
//
|
||||
// app.use(cors(corsOptions_SECURISEE)); // <--- Testez ceci ensuite
|
||||
|
||||
// ==========================================================
|
||||
|
||||
// --- Déclaration des routes ---
|
||||
app.use('/', indexRouter);
|
||||
|
||||
// catch 404 and forward to error handler
|
||||
app.use(function(req, res, next) {
|
||||
next(createError(404, 'Route non trouvée'));
|
||||
});
|
||||
|
||||
// error handler (renvoie du JSON)
|
||||
app.use(function(err, req, res, next) {
|
||||
res.status(err.status || 500);
|
||||
res.json({
|
||||
error: {
|
||||
message: err.message,
|
||||
status: err.status
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
module.exports = app;
|
||||
Reference in New Issue
Block a user