1. はじめに
HTTP 駆動のアプリケーションはステートレスであるため、ユーザーのリクエスト情報を保存するために Session を使用します。 Laravel は、クリーンで統合された API を通じてさまざまなバックエンド セッション ドライバーを処理します。現在サポートされている人気のバックエンド ドライバーには、Memcached、Redis、データベースなどがあります。
1.1 設定
セッション設定ファイルは config/session.php にあります。デフォルトでは、Laravel で使用されるセッションドライバーはファイル駆動型であり、多くのアプリケーションでは問題ありません。実稼働環境では、セッションのパフォーマンスを高速化するために、memcached ドライバーまたは redis ドライバーの使用を検討できます。
セッションドライバーは、リクエストされたセッションデータが保存される場所を定義します。安全な Cookie で暗号化されます。
- データベース – セッション データはデータベースに保存されます。
- memcached / redis – セッション データは memcached/redis に保存されます。
- 配列 – セッション データは単純な PHP 配列に保存されます。複数のリクエストの間で変換されます。 永続的。
- 注: アレイ ドライバーは、セッション データの永続化を避けるためにテストを実行するためによく使用されます。
データベース
データベースセッションドライバーを使用する場合、セッション項目を含めるようにテーブルを設定する必要があります。 以下は、データテーブルのテーブル構造宣言です。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 ドライバーを使用できるようになります。

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPロギングは、Webアプリケーションの監視とデバッグ、および重要なイベント、エラー、ランタイムの動作をキャプチャするために不可欠です。システムのパフォーマンスに関する貴重な洞察を提供し、問題の特定に役立ち、より速いトラブルシューティングをサポートします

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

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

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

ホットトピック



