Node.js-具有await函数的超时(如果未完成,则抛出新的错误)

时间:2018-12-15 14:18:59

标签: node.js

这是我的代码:

router.post('/route', indexValidator, async (req, res, next) => {
  try {
    const data = await action.access(req);
    res.send(data);
  } catch (err) {
    next(err);
  }
});

如果“ await action.access(req);”,我想返回一个错误“ throw new Error()”。耗时超过60秒。我该怎么办?

我尝试过:

router.post('/route', indexValidator, async (req, res, next) => new Promise(async (resolve, rej) => {
  try {
    let data;
    setTimeout(async () => {
      rej(new Error('No more time'));
    }, 3000);

    resolve(data = await action.access(req));
    res.send(data);
  } catch (err) {
    next(err);
  }
}));

但是代码继续运行,并且在超时运行时出现此错误:

(node:8765) UnhandledPromiseRejectionWarning: Error: No more time

2 个答案:

答案 0 :(得分:0)

因此在此问题中,如果您在60秒内获得数据,则必须清除超时。所以你可以做这样的事情

router.post('/route', indexValidator, async (req, res, next) => new Promise(async (resolve, rej) => {
  try {
    let data;
    const timer = setTimeout(async () => {
      rej(new Error('No more time'));
    }, 1000 * 60);
    const data = await action.access(req);
    clearTimeout(timer)
    resolve(data);
    res.send(data);
    } catch (err) {
      next(err);
    }
 }));

答案 1 :(得分:0)

为什么要在路由器处理程序中创建一个Promise。而不是引发错误,您应该向客户端发送错误消息。请尝试以下示例。希望对您有帮助。

var apiRouter = require('express').Router();

apiRouter.post('/', async(req, res, next) => {
console.log('Request Came..');
setTimeout(() => {
    next(new Error('TimedOut'));
}, 2000);
try {
    var data = await test();
    res.send(data);
} catch (err) {
    console.log('Error');
}

});

function test() {
return new Promise((resolve, reject) => {
    setTimeout(() => {
        resolve('response');
    }, 6000);
});
}

module.exports = apiRouter;