検索
ホームページバックエンド開発PHPチュートリアル[ Laravel 5.2 ドキュメント ] サービス -- セッション

1. はじめに

HTTP 駆動のアプリケーションはステートレスであるため、ユーザーのリクエスト情報を保存するために Session を使用します。 Laravel は、クリーンで統合された API を通じてさまざまなバックエンド セッション ドライバーを処理します。現在サポートされている人気のバックエンド ドライバーには、Memcached、Redis、データベースなどがあります。

1.1 設定

セッション設定ファイルは config/session.php にあります。デフォルトでは、Laravel で使用されるセッションドライバーはファイル駆動型であり、多くのアプリケーションでは問題ありません。実稼働環境では、セッションのパフォーマンスを高速化するために、memcached ドライバーまたは redis ドライバーの使用を検討できます。

セッションドライバーは、リクエストされたセッションデータが保存される場所を定義します。安全な Cookie で暗号化されます。

    データベース – セッション データはデータベースに保存されます。
  • memcached / redis – セッション データは memcached/redis に保存されます。
  • 配列 – セッション データは単純な PHP 配列に保存されます。複数のリクエストの間で変換されます。 永続的。
  • 注: アレイ ドライバーは、セッション データの永続化を避けるためにテストを実行するためによく使用されます。
1.2 セッションドライバーの予備知識

データベース

データベースセッションドライバーを使用する場合、セッション項目を含めるようにテーブルを設定する必要があります。 以下は、データテーブルのテーブル構造宣言です。
Schema::create('sessions', function ($table) {    $table->string('id')->unique();    $table->text('payload');    $table->integer('last_activity');});

を使用できます。移行を生成する Artisan コマンド session:table :

php artisan session:tablecomposer dump-autoloadphp artisan migrate

Redis

Laravel で Redis セッションドライバーを使用する前に、Composer を通じて predis/predis パッケージをインストールする必要があります。

1.3 その他のセッション関連の問題

Laravel フレームワークは内部で flashsession キーを使用するため、この名前でセッションにデータ項目を追加しないでください。

保存されているすべてのセッション データを暗号化する必要がある場合は、構成ファイルで暗号化構成を true に設定します。

2. 基本的な使用法

セッションへのアクセス

まず、コントローラー メソッドのタイプ ヒントを通じてセッション インスタンスにアクセスできます。 Laravel サービスコンテナインジェクション:

<?phpnamespace App\Http\Controllers;use Illuminate\Http\Request;use App\Http\Controllers\Controller;class UserController extends Controller{    /**     * 显示指定用户的属性     *     * @param  Request  $request     * @param  int  $id     * @return Response     */    public function showProfile(Request $request, $id)    {        $value = $request->session()->get('key');        //    }}

セッションからデータを取得するときに、get メソッドの 2 番目のパラメーターとしてデフォルト値を渡すこともできます。指定されたキーがセッションに存在しない場合は、デフォルト値が返されます。クロージャをデフォルト値として get メソッドに渡すと、クロージャが実行され、実行結果が返されます:

$value = $request->session()->get('key', 'default');$value = $request->session()->get('key', function() {    return 'default';});

セッションからすべてのデータを取得したい場合は、all メソッドを使用できます:

$data = $request->session()->all();

Youグローバル 1 つの PHP 関数セッションを使用して、セッション内のデータを取得および保存することもできます。

Route::get('home', function () {    // 从session中获取数据...    $value = session('key');    // 存储数据到session...    session(['key' => 'value']);});

指定された項目がセッション内に存在するかどうかを確認します

has メソッドを使用して、データ項目がセッション内に存在するかどうかを確認できます。存在する場合は true を返します:

if ($request->session()->has('users')) {    //}

セッションにデータを保存します

セッション インスタンスを取得した後、複数のメソッドを呼び出して基になるデータを操作できます。たとえば、put メソッドは新しいデータをセッションに保存します。

$request->session()->put('key', 'value');

配列セッションにデータをプッシュする

Push メソッドを使用すると、値が配列であるセッションにデータをプッシュできます。たとえば、user.teams キーにチーム名の配列が含まれている場合、新しい値を配列は次のようになります。

$request->session()->push('user.teams', 'developers');

データの取得と削除

pull メソッドはセッションからデータを取得して削除します。

$value = $request->session()->pull('key', 'default');

セッションからデータ項目を削除します

場合、forget メソッドは指定されたデータをセッションから削除します。セッションからすべてのデータを削除したい場合は、フラッシュ メソッドを使用できます:

$request->session()->forget('key');$request->session()->flush();

セッション ID を再生成する

セッション ID を再生成する必要がある場合は、regenerate メソッドを使用できます:

$request->session()->regenerate();

2.1 ワンタイム データ

場合によっては次のリクエストでのみ有効なデータをセッションに保存したい場合があります。これはフラッシュ メソッドを使用して実現できます。このメソッドを使用して保存されたセッション データは、後続の HTTP リクエストでのみ有効であり、その後削除されます:

$request->session()->flash('status', 'Task was successful!');

より多くのリクエストでワンタイム データを保持する必要がある場合は、フラッシュ メソッドを使用できます。時間データ データは次のリクエストまで保持されます。特定の 1 回限りのデータを保存したい場合は、keep メソッドを使用できます。

$request->session()->reflash();$request->session()->keep(['username', 'email']);

3. カスタム セッション ドライバーを追加します

Laravel バックエンドセッションでは、セッションファサードで extend メソッドを使用できます。このメソッドは、サービス プロバイダーのブート メソッドで呼び出すことができます:

<?phpnamespace App\Providers;use Session;use App\Extensions\MongoSessionStore;use Illuminate\Support\ServiceProvider;class SessionServiceProvider extends ServiceProvider{    /**     * Perform post-registration booting of services.     *     * @return void     */    public function boot()    {        Session::extend('mongo', function($app) {            // Return implementation of SessionHandlerInterface...            return new MongoSessionStore;        });    }    /**     * Register bindings in the container.     *     * @return void     */    public function register()    {        //    }}

カスタム セッション ドライバーは、SessionHandlerInterface インターフェイスを実装する必要があることに注意してください。これには、実装する必要があるいくつかのメソッドが含まれています。 MongoDB の実装は次のとおりです。
<?phpnamespace App\Extensions;class MongoHandler implements SessionHandlerInterface{    public function open($savePath, $sessionName) {}    public function close() {}    public function read($sessionId) {}    public function write($sessionId, $data) {}    public function destroy($sessionId) {}    public function gc($lifetime) {}}

これらのメソッドは、キャッシュされた StoreInterface インターフェイス メソッドほど理解するのが簡単ではありません。各メソッドを簡単に説明します。
  • open メソッドはファイルベースのセッション ストレージ システムに使用されます。Laravel には既にファイル セッション ドライバーが含まれているため、このメソッドにコードを配置する必要はなく、空のメソッドに設定できます。
  • close メソッドは open メソッドと同じであるため、このメソッドはほとんどのドライバーでは使用されません。
  • read メソッドは、指定された $sessionId に一致するセッション データの文字列バージョンを返す必要があります。ドライバーからのセッション データの取得または保存には、Laravel がすでにシリアル化を行っているため、シリアル化やその他のエンコーディングは必要ありません。
  • write メソッドは、指定された $data を、MongoDB、Dynamo などの永続ストレージ システムの対応する $sessionId に書き込む必要があります。
  • destroy メソッドは、$sessionId に対応するデータを永続ストレージから削除します。
  • gc メソッドは、指定された $lifetime を超えるすべてのセッション データを破棄します。Memcached や Redis など、独自の有効期限メカニズムを持つシステムの場合、このメソッドは空のままにすることができます。

セッションドライバーが登録されると、構成ファイル config/session.php で mongo ドライバーを使用できるようになります。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPでインターフェイスをどのように作成して使用しますか?PHPでインターフェイスをどのように作成して使用しますか?Apr 30, 2025 pm 03:40 PM

この記事では、PHPでインターフェイスを作成、実装、および使用する方法について説明し、コード組織と保守性の利点に焦点を当てています。

crypt()とpassword_hash()の違いは何ですか?crypt()とpassword_hash()の違いは何ですか?Apr 30, 2025 pm 03:39 PM

この記事では、PHPのCrypt()とpassword_hash()の違いについて、パスワードハッシュの違いについて説明し、最新のWebアプリケーションの実装、セキュリティ、および適合性に焦点を当てています。

PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?Apr 30, 2025 pm 03:38 PM

記事では、入力検証、出力エンコード、およびOWASP ESAPIやHTML浄化器などのツールを使用して、PHPのクロスサイトスクリプト(XSS)を防止します。

PHPの自動装置は何ですか?PHPの自動装置は何ですか?Apr 30, 2025 pm 03:37 PM

PHPでのオートローディングは、必要に応じてクラスファイルを自動的にロードし、メモリの使用を削減し、コード組織を強化することでパフォーマンスを向上させます。ベストプラクティスには、PSR-4の使用とコードを効果的に整理することが含まれます。

PHPストリームとは何ですか?PHPストリームとは何ですか?Apr 30, 2025 pm 03:36 PM

PHPストリームは、一貫したAPIを介したファイル、ネットワークソケット、圧縮形式などのリソースの処理を統合し、複雑さを抽象化し、コードの柔軟性と効率を高めます。

PHPを使用してアップロードできるファイルの最大サイズはどれくらいですか?PHPを使用してアップロードできるファイルの最大サイズはどれくらいですか?Apr 30, 2025 pm 03:35 PM

この記事では、PHPでファイルアップロードサイズの管理を管理し、2MBのデフォルト制限とPHP.ini設定を変更してそれを増やす方法に焦点を当てています。

PHPのめまいの種類とは何ですか?PHPのめまいの種類とは何ですか?Apr 30, 2025 pm 03:34 PM

この記事では、PHP 7.1で導入されたPHPのヌル可能なタイプについて説明し、変数またはパラメーターが指定されたタイプまたはnullのいずれかを可能にします。読みやすさの改善、タイプの安全性、明示的な意図などの利点を強調し、宣言する方法を説明します

unset()とlink()関数の違いは何ですか?unset()とlink()関数の違いは何ですか?Apr 30, 2025 pm 03:33 PM

この記事では、プログラミングのunset()とlink()関数の違いについて説明し、目的とユースケースに焦点を当てています。 unset()はメモリから変数を削除しますが、link()はファイルシステムからファイルを削除します。どちらもEFFECにとって重要です

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール