我正在使用Node.js请求模块请求,如此
let request = require('request');
request(SOME_URL, { proxy }, function (error, response, body) {
if (error) {
console.log('Error: ' + error);
return;
}
// my actual code here that usually runs
});
98%的时间可以使用,但有时候我会使用一个代理,这会导致一些奇怪的行为。我的代码将一直嗡嗡作响,直到突然停止以下堆栈跟踪:
assert.js:85
throw new assert.AssertionError({
^
AssertionError: 542 == 0
at ClientRequest.onConnect (/home/stephen/apps/my-cool-app/node_modules/tunnel-agent/index.js:159:14)
at ClientRequest.g (events.js:291:16)
at emitThree (events.js:116:13)
at ClientRequest.emit (events.js:194:7)
at Socket.socketOnData (_http_client.js:395:11)
at emitOne (events.js:96:13)
at Socket.emit (events.js:188:7)
at readableAddChunk (_stream_readable.js:176:18)
at Socket.Readable.push (_stream_readable.js:134:10)
at TCP.onread (net.js:548:20)
现在,我希望在回调中返回任何错误。但那并没有发生,所以我无法在那里妥善处理。
我尝试在try / catch块中包含它,如下所示:
try {
request(SOME_URL, { proxy }, function (error, response, body) {
if (error) {
console.log('Error: ' + error);
return;
}
// my actual code here that usually runs
});
} catch (err) {
console.log('Caught error: ' + err);
}
但这也不起作用 - 我仍然得到AssertionError,我的程序停止了。
所以,我的问题是:我如何优雅地处理这个问题?如果我遇到这个AssertionError
我想取消(或忽略)请求并继续使用另一个请求,不要让我的程序崩溃。
答案 0 :(得分:1)
这可能是处理这些不受欢迎的断言的唯一方法:
process.on('uncaughtException', err => {
if (err.name === 'AssertionError') {
// handle the assertion here or just ignore it..
}
});