Koa.js - Gestion des erreurs

La gestion des erreurs joue un rôle important dans la création d'applications Web. Koa utilise également un middleware à cette fin.

Dans Koa, vous ajoutez un middleware qui fait try { yield next }comme l'un des premiers middleware. Si nous rencontrons une erreur en aval, nous retournons à la clause catch associée et traitons l'erreur ici. Par exemple -

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

//Error handling middleware
app.use(function *(next) {
   try {
      yield next;
   } catch (err) {
      this.status = err.status || 500;
      this.body = err.message;
      this.app.emit('error', err, this);
   }
});

//Create an error in the next middleware
//Set the error message and status code and throw it using context object

app.use(function *(next) {
   //This will set status and message
   this.throw('Error Message', 500);
});

app.listen(3000);

Nous avons délibérément créé une erreur dans le code ci-dessus et gérons l'erreur dans le bloc catch de notre premier middleware. Celui-ci est ensuite émis sur notre console et envoyé comme réponse à notre client. Voici le message d'erreur que nous recevons lorsque nous déclenchons cette erreur.

InternalServerError: Error Message
   at Object.module.exports.throw 
      (/home/ayushgp/learning/koa.js/node_modules/koa/lib/context.js:91:23)
   at Object.<anonymous> (/home/ayushgp/learning/koa.js/error.js:18:13)
   at next (native)
   at onFulfilled (/home/ayushgp/learning/koa.js/node_modules/co/index.js:65:19)
   at /home/ayushgp/learning/koa.js/node_modules/co/index.js:54:5
   at Object.co (/home/ayushgp/learning/koa.js/node_modules/co/index.js:50:10)
   at Object.toPromise (/home/ayushgp/learning/koa.js/node_modules/co/index.js:118:63)
   at next (/home/ayushgp/learning/koa.js/node_modules/co/index.js:99:29)
   at onFulfilled (/home/ayushgp/learning/koa.js/node_modules/co/index.js:69:7)
   at /home/ayushgp/learning/koa.js/node_modules/co/index.js:54:5

À l'heure actuelle, toute demande envoyée au serveur entraînera cette erreur.