- 1、本文档共3页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Express 错误处理
Express 错误处理
错误处理
定义错误处理中间件和定义其他中间件⼀样,除了需要 4 个参数,⽽不是 3 个,其格
式如下 (err, req, res, next)。例如
app.use(function(err, req, res, next) {
console.error(err.stack);
res.status(500).send(Something roke!);
});
在其他 app.use() 和路由调⽤后,最后定义错误处理中间件,⽐如
var odyParser = require( ody-parser);
var methodOverride = require(method-override);
app.use( odyParser());
app.use(methodOverride());
app.use(function(err, req, res, next) {
// 业务逻辑
});
中间件返回的响应是随意的,可以响应⼀个 HTML 错误页⾯、⼀句简单的话、⼀个
JSON 字符串,或者其他任何您想要的东西。
为了便于组织 (更⾼级的框架),您可能会像定义常规中间件⼀样,定义多个错误处
理中间件。⽐如您想为使⽤ XHR 的请求定义⼀个,还想为没有使⽤的定义⼀个,那
么
var odyParser = require( ody-parser);
var methodOverride = require(method-override);
app.use( odyParser());
app.use(methodOverride());
app.use(logErrors);
app.use(clientErrorHandler);
app.use(errorHandler);
logErrors 将请求和错误信息写⼊标准错误输出、⽇志或类似服务
function logErrors(err, req, res, next) {
console.error(err.stack);
next(err);
}
clientErrorHandler 的定义如下 (注意这⾥将错误直接传给了 next)
function clientErrorHandler(err, req, res, next) {
if (req.xhr) {
res.status(500).send({ error: Something lew up! });
} else {
next(err);
}
}
errorHandler 能捕获所有错误,其定义如下
function errorHandler(err, req, res, next) {
res.status(500);
res.render(error, { error: err });
}
如果向 next() 传⼊参数 (除了 ‘route’ 字符串),Express 会认为当前请求有错误的
输出,因此跳过后续其他⾮错误处理和路由/ 中间件函数。如果需做特殊处理,需要创
建新的错误处理路由,如下节所⽰。
如果路由句柄有多个回调函数,可使⽤ ‘route’ 参数跳到下⼀个路由句柄。⽐如
app.get(/a_route_ ehind_paywall,
function checkIfPaidSu scri er(req, res, next) {
if(!req.user.hasPaid) {
// 继续处理该请求
next(route);
}
}, function getPaidContent(req, res, next) {
PaidContent.find(function(err, doc) {
if(err) return next(err);
res.json(doc);
});
});
在这个例⼦中,句柄 getPaidContent 会被跳过,但 app 中为
/a_route_ ehind_paywall 定义的其他句柄则会继续执⾏。
next() 和 next(err) 类似于 Promise.resolve() 和 Promise.reject()。它
们让您可以向 Express 发信号,告诉它当前句柄执⾏结束并且处于什么状
态。next(err) 会跳过
文档评论(0)