php – 如何从SESSID获取$_SESSION数据?

我有一个 PHP websocket服务器( https://github.com/lemmingzshadow/php-websocket/).

用户连接时,我想设置/获取一些会话数据.

问题是我不能使用$_SESSION,因为如果我这样做,而不是客户端会话,我得到我的websocket服务器的会话.

我设法得到客户的SESSID:

private function handshake($data) { 
    $this->log('Performing handshake');  
    if(preg_match("/PHPSESSID=(.*?)(?:;|\r\n)/",$data,$matches)){
        $sessid = $matches[1];
    }
    /* Do handshake */
}

但现在我不知道如何获得与该SESSID相关的会话数据.

我似乎已经解决了它(但我必须更多地测试它):
private function handshake($data) { 
    $this->log('Performing handshake');
    if(preg_match("/PHPSESSID=(.*?)(?:;|\r\n)/",$matches)){
        $this->sessID = $matches[1];
        session_id($this->sessID);
        @session_start();
        if(isset($_SESSION['userName'])){
            $this->userName = $_SESSION['userName'];
        }else{
            $_SESSION['userName'] = $this->userName;
        }
        session_write_close();
    }else{
        $this->log('No SESSID');    
        return false;
    }
    /* Do handshake */
}

并在我的客户端页面index.PHP上启用会话cookie

<?PHP
session_start();
?>
<!DOCTYPE html>
<!-- Page's HTML -->

说明

首先,我使用session_id,以便下面的session_start()将给出与给定SESSID相关的会话.

然后,我可以使用@session_start()来启动会话.它需要@因为websocket服务器已经启动,所以不使用它会产生:

> PHP警告:session_start():无法发送会话cookie – 已发送的标头
> PHP警告:session_start():无法发送会话缓存限制器 – 已发送的标头

现在我可以用$_SESSION做我想做的事.

最后,我使用session_write_close()关闭会话.必须使用它,因为:

> session_id必须在session_start()之前调用.如果会话未关闭,当第二个客户端连接时,会话将已打开,因此session_id将无法运行.>避免会话锁定.正如@sven所说,只有一个PHP运行实例可以访问会话文件.由于websocket服务器的脚本应该运行很长时间,因此一旦打开会话,如果不关闭会话,就不能在其他脚本中使用会话.

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...