2

在 Cloud9 ide 上同时使用 Express 和 socket.io 时出现以下错误:

http.js:707
    throw new Error('Can\'t set headers after they are sent.'); ^ 错误:发送后无法设置标题。
    在 ServerResponse.OutgoingMessage.setHeader (http.js:707:11)
    在 ServerResponse.res.setHeader (/var/lib/stickshift/523075494382ec51c3000001/app-root/data/610464/node_modules/express/node_modules/connect/lib/patch.js:59:22)
    在下一个(/var/lib/stickshift/523075494382ec51c3000001/app-root/data/610464/node_modules/express/node_modules/connect/lib/proto.js:153:13)
    在 Function.app.handle (/var/lib/stickshift/523075494382ec51c3000001/app-root/data/610464/node_modules/express/node_modules/connect/lib/proto.js:198:3)
    在 Server.app (/var/lib/stickshift/523075494382ec51c3000001/app-root/data/610464/node_modules/express/node_modules/connect/lib/connect.js:65:37)
    在 Manager.handleRequest (/var/lib/stickshift/523075494382ec51c3000001/app-root/data/610464/node_modules/socket.io/lib/manager.js:564:28)
    在服务器。(/var/lib/stickshift/523075494382ec51c3000001/app-root/data/610464/node_modules/socket.io/lib/manager.js:118:10)
    在 Server.EventEmitter.emit (events.js:117:20)
    在 HTTPParser.parser.onIncoming (http.js:2056:12)
    在 HTTPParser.parserOnHeadersComplete [如 onHeadersComplete] (http.js:120:23)

下面是我的 server.js 代码:

var express = require('express');
var app = express()
  , http = require('http')
  , server = http.createServer(app)
  , io = require('socket.io').listen(server);


server.listen(process.env.PORT, process.env.IP);

app.get('/', function(req,res) {
    res.writeHead(200, {'Content-Type': 'text/plain'});
    res.write('Hello World\n');
})

我正在使用节点:“0.10.x”,socket.io:“0.9.14”并表达:“3.x”。此错误仅在 Cloud9 ide 上出现。在 localhost 上运行良好。请帮忙。

4

1 回答 1

0

我遇到了同样的问题。虽然这不是一个好的解决方案,但将 Express 恢复到 3.1.0 版本为我解决了这个问题。从高层次上看,Express 和 Socket.io 的最新版本不能很好地协同工作。

我恢复后使用的版本是:

节点:0.10.x

Socket.io: 0.9.16 ,

快递:3.1.0

于 2013-11-19T04:16:35.530 回答