问题描述:
系统: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了。
Error: Can't set headers after they are sent.
时间: 2024-10-07 09:33:11