目前咱们项目的Nodejs异常是经过express next 到 errorhandler 中间件去处理的, 本来觉得此方法能够捕获到全部的异常,但事实发现并不是如此。 下面以一个异常举例子:前端
req.get('',function(req, res, next){ var a = undefined.b; // 产生了一个exception }) req.use(function(){req, res, next}{ next(); //最终到 errorhandler中间件中处理 })
上面这个例子中,咱们人为的制造了一个excepteion,同时咱们指望的结果是异常能进入到咱们写好的handler中去作处理。 从上面代码的运行结果来看,也符合咱们的预期。 若是换个地方抛出异常,结果就不是咱们想要的了。node
req.get('',function(req, res, next){ redis.get('key', function(){ var a = undefined.b; // 产生了一个exception })//欢迎加入全栈开发交流圈一块儿学习交流:864305860 }) req.use(function(){req, res, next}{ next(); //最终到 errorhandler中间件中处理 })
上面的代码抛出的异常并不会被express捕获,也不会被next到咱们的错误处理器中,而是会下面的代码捕获redis
process.on('uncaughtException', uncaughtExceptionHandler);
nodejs中,异步回调中的异常是没法被外围的try catch捕获的。express
req.get('',function(req, res, next){ try{//欢迎加入全栈开发交流圈一块儿学习交流:864305860 redis.get('key', function(){ var a = undefined.b; // 产生了一个exception })//欢迎加入全栈开发交流圈一块儿学习交流:864305860 }catch(e){ //并不会进到这里来 } })
解决方案:promise
function promiseFun() { return new Promise(function (resolve, reject) { redis.get('key', function(){ resolve("Hello"); // reject(); })//欢迎加入全栈开发交流圈一块儿学习交流:864305860 })//面向1-3年前端人员 }//帮助突破技术瓶颈,提高思惟能力 promiseFun().then().catch();
var getAsync1 = await async1(); async function async1() { return new Promise(function (resolve, reject) { redis.get('key', function(){ resolve("Hello"); // reject(); }) }); }//欢迎加入全栈开发交流圈一块儿学习交流:864305860 console.log(getAsync1);
But … 若是是下面这样写异步
function promiseFun() { return new Promise(function (resolve, reject) { redis.get('key', function(){ throw Error(); //依然捕获不到 }) }) }//欢迎加入全栈开发交流圈一块儿学习交流:864305860 promiseFun().then().catch();
结语async
感谢您的观看,若有不足之处,欢迎批评指正。学习