node.js express捕获全局异常的三种方法实例分析


Posted in Javascript onDecember 27, 2019

本文实例讲述了node.js express捕获全局异常的三种方法。分享给大家供大家参考,具体如下:

场景

express的路由里抛出异常后,全局中间件没办法捕获,需要在所有的路由函数里写try catch,这坑爹的逻辑让人每次都要多写n行代码

官方错误捕获中件间代码如下

app.use(function(err, req, res, next) {
 console.error(err.stack);
 res.status(500).send('Something broke!');
});

测试证明客户端已经卡死,没有返回结果

解决方法一

process.on('uncaughtException', function(err) {
 console.log('Caught exception: ' + err);
});

虽然可以捕获,在命令行有输出,但是没办法给客户端返回错误了

解决方法二

const Layer = require('express/lib/router/layer');
Object.defineProperty(Layer.prototype, 'handle', {
  enumerable: true,
  get() {
    return this.__handle;
  },
  set(fn) {
    if (fn.length === 4) {
      this.__handle = fn;
    } else {
      this.__handle = (req, res, next) =>
        Promise.resolve()
          .then(() => fn(req, res, next))
          .catch(next);
    }
  },
});

解决方法三

安装express-async-errors,没错,已经有人受不了express不能捕获Promise异常搞了个破解包

地址https://github.com/davidbanham/express-async-errors

npm install express-async-errors --save

使用

var express = require('express');
require('express-async-errors');

希望本文所述对大家node.js程序设计有所帮助。

Javascript 相关文章推荐
JavaScript 仿关机效果的图片层
Dec 26 Javascript
Jquery 一次处理多个ajax请求的代码
Sep 02 Javascript
简单实用jquery版三级联动select示例
Jul 04 Javascript
本人自用的global.js库源码分享
Feb 28 Javascript
基于jQuery+JSON的省市二三级联动效果
Jun 05 Javascript
基于JavaScript如何实现私有成员的语法特征及私有成员的实现方式
Oct 28 Javascript
实例详解JSON数据格式及json格式数据域字符串相互转换
Jan 07 Javascript
js流动式效果显示当前系统时间
May 16 Javascript
使用vue与jquery实时监听用户输入状态的操作代码
Sep 19 jQuery
详解angularjs 学习之 scope作用域
Jan 15 Javascript
深入浅析ng-bootstrap 组件集中 tabset 组件的实现分析
Jul 19 Javascript
详解微信小程序之提高应用速度小技巧
Jan 07 Javascript
JavaScript中变量提升机制示例详解
Dec 27 #Javascript
vue 中 elment-ui table合并上下两行相同数据单元格
Dec 26 #Javascript
Vue使用虚拟dom进行渲染view的方法
Dec 26 #Javascript
node.js Promise对象的使用方法实例分析
Dec 26 #Javascript
js回调函数仿360开机
Dec 26 #Javascript
js仿360开机效果
Dec 26 #Javascript
element-ui中按需引入的实现
Dec 25 #Javascript
You might like
php+html5基于websocket实现聊天室的方法
2015/07/17 PHP
如何实现php图片等比例缩放
2015/07/28 PHP
php基于curl重写file_get_contents函数实例
2016/11/08 PHP
JavaScript调用堆栈及setTimeout使用方法深入剖析
2013/02/16 Javascript
jquery实现图片左右间隔滚动特效(可自动播放)
2013/05/08 Javascript
前台js对象在后台转化java对象的问题探讨
2013/12/20 Javascript
Javascript优化技巧之短路表达式详细介绍
2015/03/27 Javascript
JQuery插件Marquee.js实现无缝滚动效果
2016/04/26 Javascript
jQuery EasyUI 入门必看
2016/06/03 Javascript
AngularJS 依赖注入详解和简单实例
2016/07/28 Javascript
Es6 写的文件import 起来解决方案详解
2016/12/13 Javascript
神级程序员JavaScript300行代码搞定汉字转拼音
2017/05/20 Javascript
微信小程序 实现点击添加移除class
2017/06/12 Javascript
详解10分钟学会vue滚动行为
2017/09/21 Javascript
angularJs 表格添加删除修改查询方法
2018/02/27 Javascript
vue移动端轻量级的轮播组件实现代码
2018/07/12 Javascript
关于Vue Router中路由守卫的应用及在全局导航守卫中检查元字段的方法
2018/12/09 Javascript
微信小程序使用字体图标的方法
2019/05/23 Javascript
后台使用freeMarker和前端使用vue的方法及遇到的问题
2019/06/13 Javascript
使用Vant完成通知栏Notify的提示操作
2020/11/11 Javascript
对python中数据集划分函数StratifiedShuffleSplit的使用详解
2018/12/11 Python
Python3.5常见内置方法参数用法实例详解
2019/04/29 Python
在Django model中设置多个字段联合唯一约束的实例
2019/07/17 Python
python实现按关键字筛选日志文件
2019/12/24 Python
TensorFlow的环境配置与安装教程详解(win10+GeForce GTX1060+CUDA 9.0+cuDNN7.3+tensorflow-gpu 1.12.0+python3.5.5)
2020/06/22 Python
阻止移动设备(手机、pad)浏览器双击放大网页的方法
2014/06/03 HTML / CSS
美国蔬菜和植物种子公司:Burpee
2017/02/01 全球购物
英国最受欢迎的价格比较网站之一:MoneySuperMarket
2018/12/19 全球购物
职业生涯规划怎么写
2013/12/29 职场文书
实习推荐信
2014/05/10 职场文书
物业保安岗位职责
2014/07/02 职场文书
试用期辞职信范文
2015/03/02 职场文书
学校捐书活动总结
2015/05/08 职场文书
2015年留守儿童工作总结
2015/05/22 职场文书
工作收入证明模板
2015/06/12 职场文书
PyTorch中permute的使用方法
2022/04/26 Python