发送到特定客户端NODE javascript后socket.io断开连接

时间:2014-09-03 19:35:37

标签: javascript node.js websocket socket.io

您好我正在处理某种“聊天”系统。

服务器:NodeJs with express - https 通讯:Socket.io@1.0

客户端:

var socket = io.connect();
socket.emit('HELLO', {user:'someuserid'});
socket.on('WELCOME', function(data){
    socket.emit('REGISTER', {});
});
socket.on('SIGNED', function(data){
    console.log(data.user);
    socket.emit('GO', {});
});
socket.on('message', function(data){
    console.log(data.somedata);
});

服务器:

io.sockets.on('connection', function(socket){
    socket.on('HELLO', function(data){
        socket.user = data.user;
        socket.emit('WELCOME', socket.user);
    });
    socket.on('REGISTER', function(data){
        console.log('room: '+socket.user);
        socket.join(socket.user);
        socket.emit('SIGNED', socket.user);
        console.log('SIGNED IN: '+socket.user);

    });
    socket.on('GO', function(data){
        //some logic happens where a list of users gets loaded
        //which is identical to the socket.user and its room
        //... loop
        io.in(partners[i].user).emit('message', { somedata: 'asd' });
    }

    socket.on('disconnect' ..... blaaa blaa)

所以,基本上我在这里尝试做的是创建一个解决方法,通过向特定房间发送消息来向特定用户发送消息。

这样:

 io.in(partners[i].user).emit('message', { somedata: 'asd' });

和此:

 partners[i].socket.emit('message', { somedata: 'asd' });

结果相同:

room: 540246a3e4b0a64a28e1ec59
SIGNED IN: 540246a3e4b0a64a28e1ec59
room: 540504ba0b526b274398480e
SIGNED IN: 540504ba0b526b274398480e
to: 540246a3e4b0a64a28e1ec59
disconnected:540246a3e4b0a64a28e1ec59

用户注册,连接并希望向阵列合作伙伴[i]中的特定聊天伙伴发出消息。

一旦向用户发射了发射,就应该发出消息以断开连接......

我做错了什么?

(脚本显然不完整..我粘贴了最重要的部分)

感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

我想我找到了解决方案:

有时使用谷歌比自己调试更省力。

滚动浏览firefox中的调试日志后,我发现这个问题实际上与我的socket' message'中的代码有关。处理程序。一个可能帮助其他人查找套接字错误的代码段:

socket.on('error', function (err) {
  if (err.description) throw err.description;
  else throw err; // Or whatever you want to do
});

我认为这是socket.io中的一个问题 虽然这是我错误的代码 - socket.io错误处理程序应该通过它。

玩得开心