Socket.io断开事件错误地为其他用户触发,然后再次连接

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Socket.io断开事件错误地为其他用户触发,然后再次连接相关的知识,希望对你有一定的参考价值。

我在socket.io库中为Node.js的disconnect事件有问题。当我断开一个用户(关闭客户端应用程序)时,不仅为这一个用户而且为所有连接的用户触发断开连接事件。在此之后,他们再次重新连接。

我想只断开这个特定的用户。所有其他人应该仍然连接。

如下所示,同时为这些用户触发断开连接事件,并且它们也在同一时间连接。

黄线没问题,但下面标记为红色不应该发生。

Socket.io events

'use strict';
var events = require('./events.js');
var player = require('./player.js');
var moment = require('moment');

var express = require('express');
var app = express();
var server = require('http').createServer(app);
var io = require('socket.io').listen(server);
var uuid = require('uuid');


app.set('port', process.env.PORT || 3000);

// all connected clients
var clients = [];

server.listen(app.get('port'), function () {
    console.log("---------- SERVER IS RUNNING ----------");
});

io.on("connection", function (socket) {
    socket.uuid = uuid.v1();
    clients.push(socket);
    PrintEvent("connection", socket);

    socket.on("disconnect", function () {
        socket.broadcast.emit("USER_DISCONNECTED", socket.playerID);
        var i = clients.indexOf(socket);
        clients.splice(i, 1);

        PrintEvent("disconnect", socket);
    });
});

function PrintEvent(eventName, socket) {
    console.log(moment().format("YYYY-MM-DD HH:mm:ss") + "( " + clients.length + " ) " + eventName + " socketID: " + socket.id);
}

很少有技术服务器细节:

  • npm -v:5.5.1
  • 因为-v:v 8 9. 0
  • socket.IO: 2.0.4

很少有技术客户详细信息:

  • 来自assetstore的Unity 3D + socket.io免费插件

请你帮助我好吗?我不知道它为什么不能正常工作。

答案

据说Unity3D插件调用Socket.IO导致了这个问题。当我使用Node.js编写的客户端测试服务器代码时,一切正常。

我也开始测试另一个插件Best HTTP,我可以确认它没有造成这个断开连接错误。到现在为止还挺好 ;)

以上是关于Socket.io断开事件错误地为其他用户触发,然后再次连接的主要内容,如果未能解决你的问题,请参考以下文章

socket.io:没有触发断开事件

socket io:如何传递参数来断开套接字事件?

Node.js + Web Socket 打造即时聊天程序嗨聊(下)

Socket.IO处理断开事件

如何从 socket.io 获取原生事件数组?

Socket.io 断开事件和相关闭包的垃圾收集