我有一个
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 */ }
<?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服务器的脚本应该运行很长时间,因此一旦打开会话,如果不关闭会话,就不能在其他脚本中使用会话.