Socket.IO:重新连接导致服务器连接代码运行两次

Socket.IO: Reconnect Causes Server Connect Code to Run Twice

本文关键字:运行 两次 代码 连接 IO 重新连接 服务器 Socket      更新时间:2023-11-06

每当我使用socket.disconnect();断开连接,然后使用socket.connect();重新连接时,服务器都会运行两次握手代码。奇怪的是,尽管服务器连接代码运行了两次,但在重新连接后,我的数组中只有一个连接。这种情况发生在意外断开连接、故意断开连接或服务器重新启动时。代码位:

io.on('connection', OnConnect);
function OnConnect(socket) {
    var connection = { socket: socket, realIp: ip, token: GenerateConnToken() };
    connections.push(connection);
    console.log('Connected');
    // Client will respond to this by emitting "client-send-info".
    // This is emitted once on initial connect, but twice on reconnect.
    socket.emit('acknowledge', connection.token);
    socket.on('client-send-info', function() {
        console.log('Client Sent Info');
    });
    socket.on('disconnect', function() {
        console.log('Disconnected');
    });
}

当客户端连接、断开连接,然后重新连接一次时,上面的代码将生成以下日志:

已连接

客户端发送信息

断开

已连接

客户端发送信息

客户端发送信息

为什么在重新连接时,连接代码会运行两次,但只创建一个连接对象?

编辑:经过进一步检查,当客户端重新连接时,我的另一段连接代码似乎被执行了两次。上述代码已更新,以反映相关信息。

奇怪的是,解决方案完全是客户端的。代替以下代码:

var socket = io.connect();
socket.on('connect' function() {
    socket.on('acknowledge', function() {
    });
});

你必须使用:

var socket = io.connect();
socket.on('connect' function() {
});
socket.on('acknowledge', function() {
});

否则,当服务器实际上只发送一个发射时,它将看起来发送多个发射,而客户端错误地接收了多个发射。使用第二种代码格式,客户端在不接收多次发射的情况下成功地进行了初始连接、断开连接和重新连接。

简单地说,不要在on('connection')调用中放入任何额外的socket.on('x')调用。把它们都放在外面。