Express.js 全局錯(cuò)誤處理實(shí)現(xiàn)
全局錯(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
然后引入即可:
require('express-async-errors');POST 127.0.0.1:8080/,這次成功捕獲到了異步錯(cuò)誤!
到此這篇關(guān)于Express.js 全局錯(cuò)誤處理實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Express 全局錯(cuò)誤處理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Node.js從字符串生成文件流的實(shí)現(xiàn)方法
這篇文章主要介紹了Node.js從字符串生成文件流的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
NodeJs通過(guò)async/await處理異步的方法
本篇文章主要介紹了NodeJs通過(guò)async/await處理異步的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
使用koa2創(chuàng)建web項(xiàng)目的方法步驟
這篇文章主要介紹了使用koa2創(chuàng)建web項(xiàng)目的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-03-03
Node.js學(xué)習(xí)之地址解析模塊URL的使用詳解
url模塊是nodejs里面的一個(gè)簡(jiǎn)單的模塊,下面這篇文章主要給大家介紹了關(guān)于Node.js學(xué)習(xí)之地址解析模塊URL使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-09-09
Nodejs中怎么實(shí)現(xiàn)函數(shù)的串行執(zhí)行
今天小編就為大家分享一篇關(guān)于Nodejs中怎么實(shí)現(xiàn)函數(shù)的串行執(zhí)行,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03
Node解決簡(jiǎn)單重復(fù)問(wèn)題系列之Excel內(nèi)容的獲取
這篇文章主要給大家介紹了關(guān)于利用Node解決簡(jiǎn)單重復(fù)問(wèn)題系列之Excel內(nèi)容獲取的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧。2018-01-01
基于nodejs的微信JS-SDK簡(jiǎn)單應(yīng)用實(shí)現(xiàn)
這篇文章主要介紹了基于nodejs的微信JS-SDK簡(jiǎn)單應(yīng)用實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-05-05

