EasySwoole Session 组件 2.x
由于在 Swoole 协程下,php 自带的 session 函数是不能使用的。为此,EasySwoole 提供了独立的 session 组件,实现 php 的 session 功能。
组件要求
- php: >=7.1.0
 - easyswoole/spl: ^1.3
 - easyswoole/utility: ^1.1
 - easyswoole/component: ^2.1
 
安装方法
composer require easyswoole/session=2.x
仓库地址
基本使用
注册 session handler
使用 session 前,需要先注册 session handler。接下来的示例使用的 session handler 是 EasySwoole 内置的 session handler,开箱即用。
注册步骤:
修改 EasySwoole 全局的 event 文件(即框架根目录的 EasySwooleEvent.php 文件),在 mainServerCreate 和 HTTP 的 全局 HTTP_GLOBAL_ON_REQUEST 事件中注册 session handler。
具体实现代码如下:
<?php
namespace EasySwoole\EasySwoole;
use EasySwoole\Component\Di;
use EasySwoole\EasySwoole\AbstractInterface\Event;
use EasySwoole\EasySwoole\Swoole\EventRegister;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use EasySwoole\Session\Session;
use EasySwoole\Session\SessionFileHandler;
class EasySwooleEvent implements Event
{
    public static function initialize()
    {
        date_default_timezone_set('Asia/Shanghai');
        Di::getInstance()->set(\EasySwoole\EasySwoole\SysConst::HTTP_GLOBAL_ON_REQUEST, function (Request $request, Response $response): bool {
            // TODO: 注册 HTTP_GLOBAL_ON_REQUEST 回调,相当于原来的 onRequest 事件
            // 获取客户端 Cookie 中 easy_session 参数
            $cookie = $request->getCookieParams('easy_session');
            if (empty($cookie)) {
                $sid = Session::getInstance()->sessionId();
                // 设置客户端 Cookie 中 easy_session 参数
                $response->setCookie('easy_session', $sid);
            } else {
                Session::getInstance()->sessionId($cookie);
            }
            return true;
        });
        Di::getInstance()->set(\EasySwoole\EasySwoole\SysConst::HTTP_GLOBAL_AFTER_REQUEST, function (Request $request, Response $response): void {
            // TODO: 注册 HTTP_GLOBAL_AFTER_REQUEST 回调,相当于原来的 afterRequest 事件
        });
    }
    public static function mainServerCreate(EventRegister $register)
    {
        // 可以自己实现一个标准的 session handler,下面为组件内置实现的 session_handler
        // 基于文件存储,传入 EASYSWOOLE_TEMP_DIR 目录作为 session 数据文件存储位置
        $handler = new SessionFileHandler(EASYSWOOLE_TEMP_DIR);
        // 设置 session 数据文件存储前缀为 'easy_session',session 数据文件 savePath 为 EASYSWOOLE_TEMP_DIR
        Session::getInstance($handler, 'easy_session', EASYSWOOLE_TEMP_DIR);
    }
}
在 EasySwoole 中使用 session
注册 session handler 之后,我们就可以在 EasySwoole 控制器 的任意位置使用了。
简单使用示例代码如下:
<?php
namespace App\HttpController;
use EasySwoole\Http\AbstractInterface\Controller;
use EasySwoole\Session\Session;
class Index extends Controller
{
    public function index()
    {
        if (Session::getInstance()->get('a')) {
            var_dump(Session::getInstance()->get('a'));
        } else {
            Session::getInstance()->set('a', time());
        }
    }
    function des()
    {
        Session::getInstance()->destroy();
    }
}
然后访问 http://127.0.0.1:9501/index (示例请求地址)就可以进行测试设置 session,访问 http://127.0.0.1:9501/des (示例请求地址)就可以销毁 session