所以我有这个非常基本的 socket.io 设置,你可能已经看过一千次了。
请注意这里的文件是通过 apache 提供的。
服务器(app.js)
var io = require('socket.io').listen(8080);
io.sockets.on('connection', function(socket){
socket.emit('server ready', {msg: 'hi'}) ;
socket.on('random event', function(data) {
console.log('received');
})
});
和客户
$(document).ready(function() {
var socket = io.connect('http://127.0.0.1:8080/projectname/server/');
socket.on('server ready', function(data){
console.log('server ready!');
});
socket.emit('random event', {hurr: 'durr'});
});
但是,我得到的唯一输出是
debug - websocket writing 5:::{"name":"server ready","args":[{"msg":"hi"}]}
在节点控制台中,在客户端控制台中没有任何内容。这是错误的。
我已经尝试了来自 socket.io 网站的基本示例,它显示了完全相同的行为。它在节点控制台中记录发出的数据,但似乎没有其他任何事情发生。
编辑:经过进一步调查,在 Firefox 中访问该站点会在节点控制台中创建不同的输出:
info - handshake authorized 178702677759276313
debug - setting request GET /socket.io/1/xhr-polling/178702677759276313?t=1339080239192
debug - setting poll timeout
debug - client authorized for
debug - clearing poll timeout
debug - xhr-polling writing 1::
debug - set close timeout for client 178702677759276313
debug - xhr-polling received data packet �17�1::/stock/server/�66�5::/stock/server/:{"name":"random event","args":[{"hurr":"durr"}]}
debug - setting request GET /socket.io/1/xhr-polling/178702677759276313?t=1339080239263
debug - setting poll timeout
debug - clearing poll timeout
debug - xhr-polling writing 5:::{"name":"server ready","args":[{"msg":"hi"}]}
这看起来就像从客户端发出的数据实际上到达了服务器。但是,它似乎并没有解决实际问题:console.log 行以及客户端和服务器端都没有执行。此输出来自 Firefox 5.0.1,它似乎回退到 xhr。
提前非常感谢!