socket.io - 检查客户是否在特定房间
socket.io - check if a client is in an specific room
我想检查客户是否订阅了特定房间。我有一个数组,我在其中保存了套接字并将用户名作为索引。我已经有一个 if 子句,但它不起作用:
if(io.sockets.manager.rooms['/' + data.to].indexOf(users[partner].socket.id) >= 0) {
所以也许有人有工作代码。
更新:
代码:
/* MYSQL SETUP HERE FOR CONNECTION */
var count = 0;
var messages = 0;
var users = {};
var io = require('socket.io')(3000);
io.sockets.on('connection', function(client) {
count++;
client.emit('send login');
client.on('login user',function (data) {
if(data.name in users) {
} else {
client.u_name = data.name;
client.u_id = data.id;
users[client.u_id] = {'name':client.username,'socket':client};
io.sockets.emit('online users', { 'count': count });
}
});
client.on('disconnect', function(){
count--;
delete users[client.username];
io.sockets.emit('online users', { 'count': count });
});
client.on('join',function(room){
client.join(room);
});
client.on('leave',function(room){
client.leave(room);
});
client.on('new message',function (data) {
if(client.u_id in users) {
connection.query('INSERT INTO chats_msg(u_from,chat_id,msg) VALUES(?,?,?)', [client.u_id,data.to,data.msg], function(err, rows, fields) {
if (err) console.log(colors.red('ERROR at Query'));
query('UPDATE chats SET last_msg=?,last_time=CURRENT_TIMESTAMP,last_from=? WHERE id=?',[data.msg,client.u_id,data.to]);
});
io.sockets.in(data.to).emit('message',{'msg':data.msg,'from':client.u_name});
connection.query('SELECT * FROM chats WHERE id=? LIMIT 1', data.to, function(err, rows, fields) {
if (err) console.log(colors.red('ERROR at QUERY'));
if(rows[0].u_1 == client.u_id) {
var partner = rows[0].u_2;
} else {
var partner = rows[0].u_1;
}
if(io.sockets.manager.rooms['/' + data.to].indexOf(users[partner].socket.id) >= 0) {
users[partner].socket.emit('error msg','New message');
} else {
users[partner].socket.emit('error msg','YEAHH');
}
});
messages++;
} else {
client.emit('error msg','Client or you are not online');
}
});
});
使用socket id你可以做:
io.sockets.adapter.sids[socket.id][roomname]
如果插座在房间内则为真,否则为未定义
(版本 1.4.5)
我想检查客户是否订阅了特定房间。我有一个数组,我在其中保存了套接字并将用户名作为索引。我已经有一个 if 子句,但它不起作用:
if(io.sockets.manager.rooms['/' + data.to].indexOf(users[partner].socket.id) >= 0) {
所以也许有人有工作代码。
更新: 代码:
/* MYSQL SETUP HERE FOR CONNECTION */
var count = 0;
var messages = 0;
var users = {};
var io = require('socket.io')(3000);
io.sockets.on('connection', function(client) {
count++;
client.emit('send login');
client.on('login user',function (data) {
if(data.name in users) {
} else {
client.u_name = data.name;
client.u_id = data.id;
users[client.u_id] = {'name':client.username,'socket':client};
io.sockets.emit('online users', { 'count': count });
}
});
client.on('disconnect', function(){
count--;
delete users[client.username];
io.sockets.emit('online users', { 'count': count });
});
client.on('join',function(room){
client.join(room);
});
client.on('leave',function(room){
client.leave(room);
});
client.on('new message',function (data) {
if(client.u_id in users) {
connection.query('INSERT INTO chats_msg(u_from,chat_id,msg) VALUES(?,?,?)', [client.u_id,data.to,data.msg], function(err, rows, fields) {
if (err) console.log(colors.red('ERROR at Query'));
query('UPDATE chats SET last_msg=?,last_time=CURRENT_TIMESTAMP,last_from=? WHERE id=?',[data.msg,client.u_id,data.to]);
});
io.sockets.in(data.to).emit('message',{'msg':data.msg,'from':client.u_name});
connection.query('SELECT * FROM chats WHERE id=? LIMIT 1', data.to, function(err, rows, fields) {
if (err) console.log(colors.red('ERROR at QUERY'));
if(rows[0].u_1 == client.u_id) {
var partner = rows[0].u_2;
} else {
var partner = rows[0].u_1;
}
if(io.sockets.manager.rooms['/' + data.to].indexOf(users[partner].socket.id) >= 0) {
users[partner].socket.emit('error msg','New message');
} else {
users[partner].socket.emit('error msg','YEAHH');
}
});
messages++;
} else {
client.emit('error msg','Client or you are not online');
}
});
});
使用socket id你可以做:
io.sockets.adapter.sids[socket.id][roomname]
如果插座在房间内则为真,否则为未定义
(版本 1.4.5)