Socket.IO API Socket

Posted CodingSherlock

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Socket.IO API Socket相关的知识,希望对你有一定的参考价值。

Socket

Socket类继承自EventEmitter。覆写了emit方法,保留了EventEmitter的其他方法

socket.id

会话的唯一标识符,来自于底层的Client

socket.rooms

标识此客户端所在房间的字符串哈希值,按房间名称编制索引

socket.client

对底层Client对象的引用。

socket.conn

对底层Client传输连接的引用(engine.io Socket对象)

socket.request

一个getter代理,它返回对request发起底层engine.io的引用Client。用于访问请求标头,如Cookie或User-Agent。

socket.handshake

请求细节

{
  headers: /* 作为握手一部分的请求头信息*/,
  time: /* 创建时间(as string) */,
  address: /* 客户端ip */,
  xdomain: /* 是否跨域 */,
  secure: /* 是否为https */,
  issued: /* 创建时间 (as unix timestamp) */,
  url: /* 请求地址*/,
  query: /* 查询对象 */
}

socket.use(FN)

注册中间件

socket.send([... args] [,ack])

发送一个message事件

socket.emit(eventName [,... args] [,ack])

触发一个事件,可以包括任意的参数,支持所有可序列化的参数

ack参数时可选的,将使用客户端的响应值进行调用

io.on(‘connection‘, (socket) => {
  socket.emit(‘an event‘, { some: ‘data‘ });

  socket.emit(‘ferret‘, ‘tobi‘, (data) => {
    console.log(data); // data will be ‘woot‘
  });

  // the client code
  // client.on(‘ferret‘, (name, fn) => {
  //   fn(‘woot‘);
  // });

});

socket.on(eventName, callback)

为给定的事件注册一个回调函数

socket.once(eventName, listener) socket.removeListener(eventName, listener) socket.removeAllListeners([eventName]) socket.eventNames()

继承自EventEmitter

socket.join(room[, callback])

将客户端添加到room,并可选择触发带err签名的回调(如果有)

连接房间的机制由Server Adapter已配置的

为方便起见,每个套接字自动加入由其id标识的房间,这样可以轻松的广播消息到其他套接字

io.on(‘connection‘, (socket) => {
  socket.on(‘say to someone‘, (id, msg) => {
    // send a private message to the socket with the given id
    socket.to(id).emit(‘my message‘, msg);
  });
});

socket.join(rooms [,callback])

将客户端添加到room列表中,并可选择触发带err签名的回调(如果有)

socket.leave(room [,callback])

从room中删除客户端

socket.leave(room [,callback])

向一个或一系列房间中广播消息

socket.to(room) socket.in

io.on(‘connection‘, (socket) => {

  // to one room
  socket.to(‘others‘).emit(‘an event‘, { some: ‘data‘ });

  // to multiple rooms
  socket.to(‘room1‘).to(‘room2‘).emit(‘hello‘);

  // a private message to another socket
  socket.to(/* another socket id */).emit(‘hey‘);

  // WARNING: `socket.to(socket.id).emit()` will NOT work, as it will send to everyone in the room
  // named `socket.id` but the sender. Please use the classic `socket.emit()` instead.
});

socket.compress(value)

value值为真时,压缩事件数据。默认为true

socket.disconnect(close)

断开此客户端。如果close值为ture,则关闭底层连接。否则,只断开命名空间

Flag: ‘broadcast’

将事件广播到除发送者之外的所有socket

io.on(‘connection‘,(socket)=> { 
  socket.broadcast.emit(‘an event‘,{ some:‘data‘ }); //每个人都得到它但发送者
 });

Flag: ‘volatile’ Flag: ‘binary’

类似命名空间API中的定义

Event: ‘disconnect’

断开连接时触发

io.on(‘connection‘, (socket) => {
  socket.on(‘disconnect‘, (reason) => {
    // ...
  });
});

可能原因

Event: ‘error’

发生错误时触发

io.on(‘connection‘, (socket) => {
  socket.on(‘error‘, (error) => {
    // ...
  });
});

Event: ‘disconnecting’

在客户端将要断开连接时触发(但尚未离开rooms)

io.on(‘connection‘, (socket) => {
  socket.on(‘disconnecting‘, (reason) => {
    let rooms = Object.keys(socket.rooms);
    // ...
  });
});

Client

client.conn

对底层engine.io Socket连接的引用。

client.request

一个getter代理,它返回request对origin.io连接的引用。用于访问请求标头,如Cookie或User-Agent。

以上是关于Socket.IO API Socket的主要内容,如果未能解决你的问题,请参考以下文章

Socket.IO API Socket

通过 c# 与 socket.io 服务器通信

如果不需要回退,使用 WebSocket API 代替 Socket.io 有啥好处吗

使用 Express、Socket.io 和 Node-Telegram-Bot-Api 结束 Mocha 测试

Socket.io 无法在 Android 9(API 级别 28)上运行

使用 Socket.io 和 Redis 的节点集群问题