Gateway::isUidOnline

说明:

int Gateway::isUidOnline(mixed $uid);

(需要Gateway版本>=2.0.4) 如何查看Gateway版本

判断$uid是否在线,此方法需要配合Gateway::bindUid($client_uid, $uid)使用。

如果某uid没有通过Gateway::bindUid($client_uid, $uid)进行任何绑定,那么对该uid调用Gateway::isUidOnline($uid)将返回0。

如果某uid绑定的client_id都已经下线,那么对该uid调用Gateway::isUidOnline($uid)将返回0。

如果某uid绑定的client_id有至少有一个在线,那么对该uid调用 Gateway::isUidOnline($uid)将返回1。

参数

  • $uid

uid,可以是数字或者字符串

返回值

uid在线返回1,不在线返回0

注意:如果是客户端断网断电等极端情况掉线,客户端的onClose回调可能无法及时触发,参见onClose说明。也就是说对应客户端出现断网断电等极端掉线情况返回值可能是1,而并非期待的0。这种情况需要心跳来检测已经掉线的客户端。

范例

use \GatewayWorker\Lib\Gateway;
class Events
{
    ...

    public static function onMessage($client_id, $message)
    {
        // $message = '{"type":"say_to_one","to_uid":100,"content":"hello"}'
        $req_data = json_decode($message, true);
        $uid = $req_data['to_uid'];
        // 如果是向某个客户端发送消息
        if($req_data['type'] == 'say_to_one'))
        {
            // 如果不在线就先存起来
            if(!Gateway::isUidOnline($uid))
            {
                // 假设有个your_store_fun函数用来保存未读消息(这个函数要自己实现)
                your_store_fun($message);
            }
            else
            {
                // 在线就转发消息给对应的uid
                Gateway::sendToUid($uid, $req_data['content']);
            }
        }
    }

    ...
}
编辑于2024-03-13 17:37:33 完善本页 +发起讨论
赞助商
×