全局錯(cuò)誤處理
在前面幾節(jié)里,我們處理異常的方法都是手動(dòng)在可能引發(fā)異常的地方捕捉錯(cuò)誤,這固然是必要的,可以有針對(duì)性得處理異常,但很多時(shí)候,有許多潛在的異常,有一句話叫永遠(yuǎn)不要相信輸入的數(shù)據(jù),你永遠(yuǎn)都不知道什么時(shí)候可能會(huì)以什么方式觸發(fā)某些陰間異常從而造成系統(tǒng)崩潰。因此,我們需要有一位好幫手能幫助我們捕獲各種錯(cuò)誤
而這位好幫手就是,異常處理中間件
自定義異常處理中間件
同步異常
異常處理中間件需要傳入4個(gè)參數(shù): err,req,res和next,這樣才會(huì)被express識(shí)別為異常處理中間件
創(chuàng)建一個(gè)exhandler,并掛載到服務(wù)器上:
注意: 掛載異常處理中間件的行為必須位于所有定義的接口之下,至于理由,會(huì)在下一節(jié)《中間件》中給出解答
let exhandler = (err, req, res, next)=> {
console.error('Error:', err.message);
res.status(500).json(err);
}
app.use(exhandler);
我們?cè)趆elloWorld接口中人為拋出一個(gè)異常試一下,可以直接throw,也可以傳遞給next(事實(shí)上,意外的異常發(fā)生時(shí),會(huì)被express捕獲并傳遞給next,然后再丟給我們的異常處理中間件)
app.get('/', (req, res, next)=> {
const err = new Error();
err.name = '無(wú)法訪問(wèn)';
err.message = '對(duì)不起,網(wǎng)站正在維護(hù)中';
// next(err);
throw err;
});
測(cè)試
使用api調(diào)試工具GET 127.0.0.1:8080/,我們的程序不會(huì)崩潰,并且你將得到被封裝好的錯(cuò)誤信息,并且響應(yīng)碼是500。
{
"name": "無(wú)法訪問(wèn)",
"message": "對(duì)不起,網(wǎng)站正在維護(hù)中"
}
異步異常
上面的異常是產(chǎn)生在串行的代碼中的,那如果在異步操作中產(chǎn)生了異常呢?
我們弄一個(gè)異步異常的接口試一下:
app.post('/', async (req, res, next)=> {
res.send(await error()).end();
});
function error() {
let err = new Error('網(wǎng)站維護(hù)');
err.message = "自定義的錯(cuò)誤";
return Promise.reject(err);
}
POST 127.0.0.1:8080/,程序報(bào)錯(cuò),之前的中間件并未捕獲到這個(gè)錯(cuò)誤。
可以手動(dòng)在處理函數(shù)內(nèi)加上 try-catch 語(yǔ)句塊,但這樣比較繁瑣,一個(gè)更方便的方法是使用 express-async-errors:
npm i express-async-errors
然后引入即可:文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-495749.html
require('express-async-errors');
POST 127.0.0.1:8080/,這次成功捕獲到了異步錯(cuò)誤!文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-495749.html
下一節(jié)-中間件
到了這里,關(guān)于【Express.js】全局錯(cuò)誤處理的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!