Error: Can't set headers after they are sent.

来源:互联网 发布:陌陌协议软件 编辑:程序博客网 时间:2024/05/21 19:39

问题描述:

系统:Windows 7 x64

Node.js版本:版本是:v4.2.4 LTS

安装过程参考:《Node.js入门》Windows 7下Node.js Web开发环境搭建笔记

一段后端模拟HTTP请求的代码出现以下错误:Error: Can't set headers after they are sent.

如下图:

相关代码:

app.get('/trans', function (req, res) {var body = '';//这是需要提交的数据params = { 'source':'en', 'target':'es', 'text':'hello' }var data = qs.stringify(params);http.get("https://gateway.watsonplatform.net/language-translation/api/v2/translate?" + data, function(gres) { console.log("Got response: " + gres); gres.on('data',function(d){body += d; }).on('end', function(){  //console.log(gres.headers);  console.log(body);  res.send(body); });}).on('error', function(e) { console.log("Got error: " + e.message); });res.send(body);});
问题原因:

出现此错误的原因是因为

http.get
中的响应代码是异步的,

但在它响应之前,也就是最下面的一句“res.send(body);”已经把响应流关闭了。

解决方法:

将最下面的一句“res.send(body);”注释了就OK了。

1 0
原创粉丝点击