session管理
例子
<?php
namespace app\controller;
use support\Request;
class UserController
{
public function hello(Request $request)
{
$name = $request->get('name');
$session = $request->session();
$session->set('name', $name);
return response('hello ' . $session->get('name'));
}
}
通過$request->session();
獲得Workerman\Protocols\Http\Session
實例,通過實例的方法來增加、修改、刪除session數(shù)據(jù)。
注意:session對象銷毀時會自動保存session數(shù)據(jù),所以不要把
$request->session()
返回的對象保存在全局數(shù)組或者類成員中導致session無法保存。
獲取所有session數(shù)據(jù)
$session = $request->session();
$all = $session->all();
返回的是一個數(shù)組。如果沒有任何session數(shù)據(jù),則返回一個空數(shù)組。
獲取session中某個值
$session = $request->session();
$name = $session->get('name');
如果數(shù)據(jù)不存在則返回null。
你也可以給get方法第二個參數(shù)傳遞一個默認值,如果session數(shù)組中沒找到對應值則返回默認值。例如:
$session = $request->session();
$name = $session->get('name', 'tom');
存儲session
存儲某一項數(shù)據(jù)時用set方法。
$session = $request->session();
$session->set('name', 'tom');
set沒有返回值,session對象銷毀時session會自動保存。
當存儲多個值時使用put方法。
$session = $request->session();
$session->put(['name' => 'tom', 'age' => 12]);
同樣的,put也沒有返回值。
刪除session數(shù)據(jù)
刪除某個或者某些session數(shù)據(jù)時用forget
方法。
$session = $request->session();
// 刪除一項
$session->forget('name');
// 刪除多項
$session->forget(['name', 'age']);
另外系統(tǒng)提供了delete方法,與forget方法區(qū)別是,delete只能刪除一項。
$session = $request->session();
// 等同于 $session->forget('name');
$session->delete('name');
獲取并刪除session某個值
$session = $request->session();
$name = $session->pull('name');
效果與如下代碼相同
$session = $request->session();
$value = $session->get($name);
$session->delete($name);
如果對應session不存在,則返回null。
刪除所有session數(shù)據(jù)
$request->session()->flush();
沒有返回值,session對象銷毀時session會自動從存儲中刪除。
判斷對應session數(shù)據(jù)是否存在
$session = $request->session();
$has = $session->has('name');
以上當對應的session不存在或者對應的session值為null時返回false,否則返回true。
$session = $request->session();
$has = $session->exists('name');
以上代碼也是用來判斷session數(shù)據(jù)是否存在,區(qū)別是當對應的session項值為null時,也返回true。
助手函數(shù)session()
2020-12-09 新增
webman提供了助手函數(shù)session()
完成相同的功能。
// 獲取session實例
$session = session();
// 等價于
$session = $request->session();
// 獲取某個值
$value = session('key', 'default');
// 等價與
$value = session()->get('key', 'default');
// 等價于
$value = $request->session()->get('key', 'default');
// 給session賦值
session(['key1'=>'value1', 'key2' => 'value2']);
// 相當于
session()->put(['key1'=>'value1', 'key2' => 'value2']);
// 相當于
$request->session()->put(['key1'=>'value1', 'key2' => 'value2']);
配置文件
session配置文件在config/session.php
,內(nèi)容類似如下:
use Webman\Session\FileSessionHandler;
use Webman\Session\RedisSessionHandler;
use Webman\Session\RedisClusterSessionHandler;
return [
// FileSessionHandler::class 或者 RedisSessionHandler::class 或者 RedisClusterSessionHandler::class
'handler' => FileSessionHandler::class,
// handler為FileSessionHandler::class時值為file,
// handler為RedisSessionHandler::class時值為redis
// handler為RedisClusterSessionHandler::class時值為redis_cluster 既redis集群
'type' => 'file',
// 不同的handler使用不同的配置
'config' => [
// type為file時的配置
'file' => [
'save_path' => runtime_path() . '/sessions',
],
// type為redis時的配置
'redis' => [
'host' => '127.0.0.1',
'port' => 6379,
'auth' => '',
'timeout' => 2,
'database' => '',
'prefix' => 'redis_session_',
],
'redis_cluster' => [
'host' => ['127.0.0.1:7000', '127.0.0.1:7001', '127.0.0.1:7001'],
'timeout' => 2,
'auth' => '',
'prefix' => 'redis_session_',
]
],
'session_name' => 'PHPSID', // 存儲session_id的cookie名
// === 以下配置需要 webman-framework>=1.3.14 workerman>=4.0.37 ===
'auto_update_timestamp' => false, // 是否自動刷新session,默認關閉
'lifetime' => 7*24*60*60, // session過期時間
'cookie_lifetime' => 365*24*60*60, // 存儲session_id的cookie過期時間
'cookie_path' => '/', // 存儲session_id的cookie路徑
'domain' => '', // 存儲session_id的cookie域名
'http_only' => true, // 是否開啟httpOnly,默認開啟
'secure' => false, // 僅在https下開啟session,默認關閉
'same_site' => '', // 用于防止CSRF攻擊和用戶追蹤,可選值strict/lax/none
'gc_probability' => [1, 1000], // 回收session的幾率
];
注意
webman從1.4.0起更改了SessionHandler的命名空間,由原來的
use Webman\FileSessionHandler;
use Webman\RedisSessionHandler;
use Webman\RedisClusterSessionHandler;
改為
use Webman\Session\FileSessionHandler;
use Webman\Session\RedisSessionHandler;
use Webman\Session\RedisClusterSessionHandler;
有效期配置
當webman-framework < 1.3.14時,webman中session過期時間需要在php.ini
配置。
session.gc_maxlifetime = x
session.cookie_lifetime = x
session.gc_probability = 1
session.gc_divisor = 1000
假設設定有效期為1440秒,則配置如下
session.gc_maxlifetime = 1440
session.cookie_lifetime = 1440
session.gc_probability = 1
session.gc_divisor = 1000
提示
可使用命令php --ini
來查找php.ini
的位置