这是我的申请结构:
- app.js
- routes
---- index.js
ExpressJS
应用为development
和production
环境创建错误处理程序。这是app.js
的代码段:
app.use('/', routes); // routing is handled by index.js in the routes folder
//The following middleware are generated when you create the Express App
// catch 404 and forward to error handler
app.use(function (req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.use(function (err, req, res, next) {
res.status(err.status || 500);
res.render('error.ejs', {
message: err.message,
error: err
});
});
}
// production error handler
// no stacktraces leaked to user
app.use(function (err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: {}
});
});
在routes/index.js
内部,处理所有路由:
var router = express.Router();
router.get('/', function (req, res) {
someAsyncFunction(function(err, result) {
if (err) throw err; // Handle this error
}
});
module.exports = router;
我希望将err
传递给其中一个错误处理程序而不是抛出。我怎么能这样做?
答案 0 :(得分:7)
您必须将其传递给下一个回调,这通常是路由处理程序中的第三个参数
var router = express.Router();
router.get('/', function (req, res, next) {
someAsyncFunction(function(err, result) {
if (err) {
next(err); // Handle this error
}
}
});
module.exports = router;
调用next(err)
将允许使用以下签名在链中的中间件中捕获错误:
app.use(function (err, req, res, next){
// do something about the err
});
答案 1 :(得分:1)
您还可以创建中间件函数来处理所有路径中的错误,而无需在各处复制代码,如果需要,可以使用箭头函数。
1)。创建一个const函数来处理错误。
要么:
const handleErrorAsync = func => (req, res, next) => {
func(req, res, next).catch((error) => next(error));
};
或
const handleErrorAsync = func => async (req, res, next) => {
try {
await func(req, res, next);
} catch (error) {
next(error);
}
};
2):在路由器中,将其用于每个请求:
var router = express.Router();
router.get('/req1', handleErrorAsync(async (req, res, next) => {
let result = await someAsyncFunction1();
if(result){
// res.send whatever
}
}));
router.post('/req2', handleErrorAsync(async (req, res, next) => {
let result = await someAsyncFunction2(req.body.param1);
if(result){
// res.send whatever
}
}));
router.post('/req3', handleErrorAsync(async (req, res, next) => {
let result = await someAsyncFunction3(req.body.param1, req.body.param2);
if(result){
// res.send whatever
}
}));
module.exports = router;
3)在服务器主应用程序中处理错误:
// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.use(function (err, req, res, next) {
res.status(err.status || 500);
res.render('error.ejs', {
message: err.message,
error: err
});
});
}
// production error handler
// no stacktraces leaked to user
app.use(function (err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: {}
});
});
这样,您可以在任何路径中重用错误处理功能。另外,如果您的任何函数中有任何未处理的错误,也会捕获到它们。
尝试从Here捕获错误处理