場景
Node的Web應用框架Express的簡介與搭建HelloWorld:
https://mp.csdn.net/console/editor/html/106650798
Express中間件的應用-路由保護(登錄限制)、網站維護、頁面404:
https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/107303980
在上面介紹了消息中間件的使用后,學習下錯誤處理中間件。
在程序執行的過程中,不可避免的會出現一些無法預料的錯誤,比如文件讀取失敗,數據庫連接失敗。
錯誤處理中間件是一個集中處理錯誤的地方。
注:
博客:
https://blog.csdn.net/badao_liumang_qizhi
關注公眾號
霸道的程序猿
獲取編程相關電子書、教程推送與免費下載。
實現
打開app.js,首先定義錯誤處理中間件
//錯誤處理中間件 app.use((err,req,res,next)=>{ res.status(500).send(err.message); })
給客戶端響應500狀態碼並將錯誤信息響應給客戶端。
然后新建一個get路由請求,這里需要手動拋出一個錯誤。
app.get('/index',(req,res)=>{ throw new Error('程序發生了未知錯誤') })
完整示例代碼
const express = require('express') const app = express() app.get('/index',(req,res)=>{ throw new Error('程序發生了未知錯誤') }) //錯誤處理中間件 app.use((err,req,res,next)=>{ res.status(500).send(err.message); }) app.listen(3000, function () { console.log('Example app listening on port 3000!') })
在VSCode下新建終端或者在項目目錄下打開命令行輸入
node app.js
打開瀏覽器訪問

但是錯誤處理中間件只能讀到同步錯誤執行代碼
如果異步代碼在執行過程中出現了錯誤,這個錯誤處理中間件是沒法捕獲到的。
這時就需要手動去觸發這個錯誤處理中間件。
當程序出現錯誤時調用next()方法,並且將錯誤信息通過參數的形式傳遞給next方法,即可觸發錯誤。
所以拿讀取文件示例,首先需要引入文件讀取模塊
//引入文件讀取模塊 const fs = require('fs');
然后修改index路由方法,讓其讀取一個不存在的文件,在回調方法中判斷err對象是否為空,如果err不為空則存在錯誤,此時需要調用next方法並
傳遞err對象。
app.get('/index',(req,res,next)=>{ fs.readFile('./package.json','utf8',(err,result)=>{ //如果err對象不為空即存在錯誤 if(err!=null) { //則手動觸發錯誤處理中間件,傳遞err對象 next(err) }else{ res.send(result); } }) })
完整示例代碼
const express = require('express') const app = express() //引入文件讀取模塊 const fs = require('fs'); app.get('/index',(req,res,next)=>{ fs.readFile('./badao.txt','utf8',(err,result)=>{ //如果err對象不為空即存在錯誤 if(err!=null) { //則手動觸發錯誤處理中間件,傳遞err對象 next(err) }else{ res.send(result); } }) }) //錯誤處理中間件 app.use((err,req,res,next)=>{ res.status(500).send(err.message); }) app.listen(3000, function () { console.log('Example app listening on port 3000!') })
然后運行項目重新訪問index路由


然后將文件修改為本目錄下的package.json文件
app.get('/index',(req,res,next)=>{ fs.readFile('./package.json','utf8',(err,result)=>{ //如果err對象不為空即存在錯誤 if(err!=null) { //則手動觸發錯誤處理中間件,傳遞err對象 next(err) }else{ res.send(result); } }) })
然后再重新訪問


