IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    [原]Error: Can\'t set headers after they are sent.

    testcs_dn发表于 2016-02-17 21:24:09
    love 0

    问题描述:

    系统: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了。



沪ICP备19023445号-2号
友情链接