[英]socket.io disconnect after emitting to specific client NODE javascript
您好,我目前正在開發某種“聊天”系統。
服務器:帶有Express的NodeJ-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]中的特定chatpartners發送消息。
一旦發射了用戶,就應該發送消息以斷開連接...
我究竟做錯了什么?
(腳本顯然不完整。。我粘貼了最重要的部分)
謝謝你的幫助。
我想我已經找到了解決方案:
有時使用Google比自己調試更費力。
在firefox中瀏覽調試日志后,我發現此問題實際上與套接字“消息”處理程序中的代碼有關。 可以幫助其他人找到其套接字錯誤的代碼段:
socket.on('error', function (err) {
if (err.description) throw err.description;
else throw err; // Or whatever you want to do
});
我認為這是socket.io中的問題,盡管這是我的錯誤代碼-socket.io錯誤處理程序應該已經通過了。
玩得開心
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.