1

我正在尝试这个简单的 socket.io 示例,它可以在 Safari 中运行(从双方发送/接收)。但是,在 Chrome 中,客户端接收消息,但服务器不会接收客户端发送的消息

索引.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>

服务器.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 上

4

1 回答 1

0

您可以使用http://socket.io-test.com查看问题出在您的浏览器/代理还是您的代码上。

于 2013-06-13T20:48:37.563 回答