【发布时间】:2013-06-14 04:48:37
【问题描述】:
我正在尝试这个简单的 socket.io 示例,它可以在 Safari 中运行(从双方发送/接收)。但是,在 Chrome 中,客户端接收消息,但服务器不会接收客户端发送的消息
index.html
<!doctype html>
<html>
<head>
<title>web sockets</title>
<meta charset="utf-8">
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io.connect('http://localhost:8888');
socket.on('news', function (data) {
console.log(data);
writeMessage(data);
socket.emit('my other event', { my: 'data' });
});
function writeMessage(msg) {
var msgArea = document.getElementById("msgArea");
if (typeof msg == "object") {
msgArea.innerHTML = msg.hello;
}
else {
msgArea.innerHTML = msg;
}
}
</script>
</head>
<body>
<div id="msgArea">
</div>
</body>
</html>
server.js
var app = require('http').createServer(handler)
, io = require('/usr/local/lib/node_modules/socket.io').listen(app)
, fs = require('fs')
app.listen(8888);
function handler (req, res) {
fs.readFile(__dirname + '/index.html',
function (err, data) {
if (err) {
res.writeHead(500);
return res.end('Error loading index.html');
}
res.writeHead(200);
res.end(data);
});
}
io.sockets.on('connection', function (socket) {
socket.emit('news', { hello: 'world' });
socket.on('my other event', function (data) {
console.log(data);
});
});
我错过了什么吗? Chrome 在 v.19 上
【问题讨论】:
-
您确定 dev.intullect.com:8888 吗?因为我在我的本地主机中托管了相同的应用程序,它似乎正在工作(在 chrome 中)
-
是的...这只是我确认的虚拟主机。我也尝试使用本地主机。这一切都适用于野生动物园......只是不是铬
-
我还应该补充一点,它在 firefox v13 中也不起作用。
-
你使用什么版本的 Socket.io? Chrome、Websocket 使用什么传输方式?
-
您是否尝试删除“writeMessage(data);” ?可能 DOM 还没有准备好。
标签: socket.io