客户端未从 socket.io 中的服务器接收消息

meh*_*sen 1 javascript client-server node.js socket.io

我的服务器想在连接时向客户端发送一条消息。然后客户端向服务器发送消息。

当客户端向服务器发送消息但客户端未收到服务器应在连接上发送的初始消息时,我的代码工作正常

这是我的小代码:)

服务器

var app = require('http').createServer(handler),
  io = require('socket.io').listen(app, { log: false }),
  fs = require('fs');

app.listen(8001);

function handler(req, res) {
  fs.readFile(__dirname + '/client1.html', function(err, data) {
    if (err) {
      console.log(err);
      res.writeHead(500);
      return res.end('Error loading client1.html');
    }
    res.writeHead(200);
    res.end(data);
  });
}

io.sockets.on('connection', function (socket) {
    console.log("running time");
  socket.emit("serverMessage","server says hi");

  socket.on('clientMessage', function () {
       console.log("client message recieved");
  });      
});
Run Code Online (Sandbox Code Playgroud)

客户

 <html>
  <head>
    <script src="/socket.io/socket.io.js"></script>
       <script>
         socket = io.connect("http://localhost:8001");
          socket.on('connection', function(socket) {
               socket.on("serverMessage", function(d) {
               console.log("server send a message ");
              });          
         });
        function send() {
            socket.emit('clientMessage', "Test Message From Client");
        }
    </script>
</head>

<body>
    <button onclick="send()" >send</button>

</body>
Run Code Online (Sandbox Code Playgroud)

请任何帮助?

M O*_*ayr 6

您的客户端代码中有一个简单的错误。没有connection为客户端命名的事件。相反,名称是connect. 在客户端执行此操作:

<script>
     socket = io.connect("http://localhost:8001");
</script>
<script>
socket.on('connect', function(socket) {
    socket.on("serverMessage", function(d) {
    // you can alert something here like alert(d)
    console.log("server send a message ");
    });          
});
</script>
Run Code Online (Sandbox Code Playgroud)