Node.js中管道中未处理的流错误

时间:2016-04-16 05:21:42

标签: node.js error-handling unhandled-exception

我在Node.js和Express中使用本地代理,代码如下:

app.post('/', function(req, res){
  var newurl =  req.body.url;
  var options = {
    url: newurl,
    headers: {
     'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',
     'Accept-Language':'ru-RU,ru;q=0.8,en-US;q=0.6,en;q=0.4',
     'User-Agent':'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/48.0.2564.116 Safari/537.36'
    }
  };
  res.writeHead(200, {
    'Content-Type': 'text/html',
    'Access-Control-Allow-Origin' : '*'});
  try {
    request(options).pipe(res);
  } catch (err) {
    res.write(err.message);
    res.end();
  }
});

它适用于大多数网站,但当我尝试从某些网站检索页面时,Node会抛出以下错误:

stream.js:74
      throw er; // Unhandled stream error in pipe.
      ^

Error: socket hang up
    at createHangUpError (_http_client.js:200:15)
    at Socket.socketOnEnd (_http_client.js:285:23)
    at emitNone (events.js:72:20)
    at Socket.emit (events.js:166:7)
    at endReadableNT (_stream_readable.js:905:12)
    at nextTickCallbackWith2Args (node.js:437:9)
    at process._tickCallback (node.js:351:17)

对于任何给定的页面,它不会每次都出现,而是不时出现。因此,即使经过互联网研究,我也无法弄清楚如何解决这个问题。

1 个答案:

答案 0 :(得分:0)

这就是我解决问题的方式。 删除了尝试缓存并添加了错误事件

request({...}).on('error', error => {
res.status(502).send(error.message);
});