セッション
$_SESSION 配列の操作はサポートされておらず、Session クラスのみが使用可能です。
6.0 の Session クラスは、Swoole/Workerman などの環境を十分にサポートできます。
Open Session
Session 機能はデフォルトでは有効になっていません。Seesion を使用する必要がある場合は、グローバル ミドルウェア定義ファイルに次のミドルウェア定義を追加する必要があります。
'think\middleware\SessionInit'
マルチアプリケーション モードで、一部のアプリケーションのみに使用する場合は、アプリケーション ミドルウェア定義ファイルで個別に有効にすることもできます。
セッションの初期化
システムは、session.php で設定されたパラメータに従ってセッションを自動的に初期化します。
デフォルトでサポートされるセッション設定パラメータは次のとおりです:
パラメータ | 説明 |
---|---|
type | session type |
store | type がキャッシュ タイプに設定されている場合のストレージ識別子を指定します |
expire | セッションの有効期限 (秒) は 0 より大きくなければなりません |
var_session_id | リクエスト session_id 変数名 |
name | session_name |
prefix | セッションプレフィックス |
serialize | シリアル化方法 |
Session クラスの関連メソッドを操作なしで直接呼び出すことができます。たとえば、次のようになります。
Session::set('name', 'thinkphp'); Session::get('name');
Serialization
セッション データは自動的に作成されます。保存時にシリアル化され、読み取り時に自動的にシリアル化解除されます。シリアル化メカニズムはカスタマイズできます。
たとえば、構成ファイルで JSON シリアル化を使用するように設定します。
'serialize' => ['json_encode', 'json_decode'],
オブジェクトをセッションに保存しないようにしてください
基本的な使用法
代入
Session::set('name', 'thinkphp'); // 支持两级赋值 Session::set('user.name', 'thinkphp');
存在するかどうか判断
Session::has('name'); Session::has('user.name');
値を取得
// 如果值不存在,返回null Session::get('name'); // 如果值不存在,返回空字符串 Session::get('name', ''); // 支持多级 Session::get('user.name');
削除
Session::delete('name');
値を取得して削除
// 取值并删除 Session::pull('name');
name の値が存在しない場合は、Null が返されます。
Clear
Session::clear();
Flash データは次のリクエストまで有効です
// 设置session 并且在下一次请求之前有效 Session::flash('name','value');
現在のリクエストの有効データを事前にクリアします
// 清除当前请求有效的session Session::flush();
注データ入力操作はリクエスト終了時にローカルに保存されるため、セッションデータの書き込み後に終了やその他の割り込み操作を使用しないでください。これにより、セッションが正常に書き込まれなくなる可能性があります。
マルチレベル配列
セッションのマルチレベル配列操作をサポートします。例:
// 赋值(当前作用域) Session::set('name.item','thinkphp'); // 判断(当前作用域)是否赋值 Session::has('name.item'); // 取值(当前作用域) Session::get('name.item'); // 删除(当前作用域) Session::delete('name.item');
set メソッドと delete メソッドは 2 つのみサポートします。 -level 配列、その他のメソッドは、任意のレベルの配列操作をサポートします。
アシスタント機能
システムは、同じ機能を完了するためのアシスタント機能セッションも提供します。例:
// 赋值 session('name', 'thinkphp'); // 判断是否赋值 session('?name'); // 取值 session('name'); // 删除 session('name', null); // 清除session session(null);
セッションを読むRequest オブジェクト内
Request オブジェクト内でセッション データを読み取ることができます (設定はサポートされていません)
public function index(Request $request) { // 读取某个session数据 $request->session('user.name', ''); // 获取全部session数据 $request->session(); }
ただし、セッション書き込み操作は Request クラスではサポートされていません。
アプリケーションに依存しないセッション
デフォルトのファイル タイプが使用される場合、複数のアプリケーションのセッション保存パスは同じです。つまり、セッションは複数のアプリケーション間で共有されます。データについては、セッション データを共有したくない場合は、アプリケーションごとに異なるパスまたは異なるプレフィックスを設定できます。
ファイル タイプの場合、デフォルトのセッション データは runtime/session ディレクトリに保存されます。パスを設定して保存パスを変更できます。
他のタイプのドライバーの場合は、異なるアプリケーション セッション データを区別するためにプレフィックス構成パラメーターを設定できます。
セッション ドライバー
デフォルトのセッション ドライバーはファイル キャッシュ記録を使用し、次の構成をサポートします
説明 | |
---|---|
セッション保存パス | |
データを圧縮するかどうか | |
GCリサイクル確率 | |
GCリサイクル確率 | |
GC リサイクルの最大有効期間 |