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

问题描述:

系统: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.

如下图:

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了。