Lib\Gateway类提供的接口 - joinGroup

优质
小牛编辑
138浏览
2023-12-01

说明:

  1. void Gateway::joinGroup(string $client_id, mixed $group);

将client_id加入某个组,以便通过Gateway::sendToGroup发送数据。

可以通过Gateway::getClientSessionsByGroup($group)获得该组所有在线成员数据。
可以通过Gateway::getClientCountByGroup($group)获得该组所有在线连接数(人数)。

该方法对于分组发送数据例如房间广播非常有用。

注意:

1、同一个client_id可以加入多个分组,以便接收不同组发来的数据。

2、当client_id下线(连接断开)后,该client_id会自动从该分组中删除,开发者无需调用Gateway::leaveGroup

3、如果对应分组的所有client_id都下线,则对应分组会被自动删除。

4、目前没有提供获得所有分组id接口,所有分组名称可以自行存入数据库中。

参数

  • $client_id

客户端的client_id

  • $group

只能是数字或者字符串。

注意:group不能为空值。例如0,0.0,'0',"0",false,null是非法的group值。

范例

  1. use GatewayWorkerLibGateway;
  2. class Events
  3. {
  4. ...
  5. public static function onMessage($client_id, $message)
  6. {
  7. // $message = '{"type":"join","group":"xxxxx"}'
  8. $req_data = json_decode($message, true);
  9. Gateway::joinGroup($client_id, $req_data['group']);
  10. }
  11. ...
  12. }