ExpressJS - Gestion des erreurs

La gestion des erreurs dans Express est effectuée à l'aide d'un middleware. Mais ce middleware a des propriétés spéciales. Le middleware de gestion des erreurs est défini de la même manière que les autres fonctions de middleware, sauf que les fonctions de gestion des erreursMUST have four arguments au lieu de trois - err, req, res, next. Par exemple, pour envoyer une réponse sur n'importe quelle erreur, nous pouvons utiliser -

app.use(function(err, req, res, next) {
   console.error(err.stack);
   res.status(500).send('Something broke!');
});

Jusqu'à présent, nous gérions les erreurs dans les routes elles-mêmes. L'intergiciel de gestion des erreurs nous permet de séparer notre logique d'erreur et d'envoyer des réponses en conséquence. La méthode next () dont nous avons parlé dans le middleware nous amène au suivantmiddleware/route handler.

Pour la gestion des erreurs, nous avons le next(err)fonction. Un appel à cette fonction ignore tous les middleware et nous associe au prochain gestionnaire d'erreurs pour cette route. Comprenons cela à travers un exemple.

var express = require('express');
var app = express();

app.get('/', function(req, res){
   //Create an error and pass it to the next function
   var err = new Error("Something went wrong");
   next(err);
});

/*
 * other route handlers and middleware here
 * ....
 */

//An error handling middleware
app.use(function(err, req, res, next) {
   res.status(500);
   res.send("Oops, something went wrong.")
});

app.listen(3000);

Ce middleware de gestion des erreurs peut être stratégiquement placé après les routes ou contenir des conditions pour détecter les types d'erreur et répondre aux clients en conséquence. Le programme ci-dessus affichera la sortie suivante.