1. La configuration de serveur suivante pour capturer les exceptions de routage est-elle correcte ?
serveur.js
const express = require("express");
const app = express();
// ...加载中间件
// ...配置路由
// 异常处理
// 如果是开发环境,则打印异常到控制台
if (app.get("env") === "development") {
app.use((err, req, res, next) => {
console.error("Error",err);
next(err);
});
}
// 如果是非开发环境,则向页面输出错误信息
app.use((err, req, res, next) => {
res.status(err.status || 500);
res.render("error", {
message: err.message,
error: {}
});
});
app.listen(3000);
2. Ce qui suit est un objet de routage En l'absence de promesse (async/await), une exception sera levée normalement et capturée dans le serveur
xxxRouter.js
const router = require("express").Router();
router.all("/test/error", (req, res) => {
throw new Error("我就是异常!!!");
});
Mais en cas de promesse (async/await), une erreur sera signalée dans la console, et la capture sur le serveur ne pourra pas être capturée, ce qui entraînera q timeout
(node:30875) UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 1): Error: 我就是异常!!!
(node:30875) DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.
xxxRouter.js
const router = require("express").Router();
router.all("/test/error", async(req, res) => {
throw new Error("我就是异常!!!");
});
3. En utilisation réelle, chaque itinéraire doit essayer/capter et gérer les exceptions, ce qui semble très redondant
// 冗余的router
router.all("/test1", async(req, res) => {
try{
// ...处理一些事务
// ...各种 await
res.end(
// 成功返回内容
);
}catch(err){
// 此处希望throw err 让server接收并处理,但是会报错
res.end(
// 失败返回内容
);
}
});
// ...之后还有很多router都要try/catch依次处理异常
=、=
La fonction asynchrone renvoie un objet
Promise
. L'exception levée dans cette fonction doit transmettre lecatch()
ou lethen( )
pour gérer le deuxième paramètre.Promise
对象,这个函数中抛出的异常需要通过Promise
对象的catch()
或then()
的第 2 个参数来处理。当然如想外层函数用了
Bien sûr, si la fonction externe utiliseawait
,就不是用catch()
或then()
来处理了,而是像同步调用那样用try ... catch ...
await
, elle ne sera pas gérée aveccatch()
outhen()
, mais comme la synchronisation. Utilisezessayez ... catch ...
pour gérer l'appel.process.on('unhandledRejection', processErrorHandler);