Laravel 5.0 セッション

設定

HTTP駆動のアプリケーションはステートレスですから、リクエスト間に渡り情報を保存するセッションが提供されています。Laravelは美しく統一されたAPIで、様々なバックエンドのセッションを用意しています。人気のあるMemcachedRedis、データベースも始めからサポートしています。

セッションの設定はconfig/session.phpにあります。このファイルのオプションには詳しくコメントがついていますので、確認して下さい。ほとんどのアプリケーションでうまく動作できるように、Laravelはfileセッションドライバーをデフォルトとして設定しています。

Reidsセッションを使用する時には、Composerでpredis/predisパッケージ(~1.0)をインストールしておく必要があります。

注目: セッションに保存するデータを全て暗号化したい場合は、encrypt設定オプションをtureに設定します。

注意 cookieセッションドライバーを使用する場合は、HTTPカーネルからEncryptCookieミドルウェアを決して削除してはいけません。このミドルウェアを削除してしまうと、リモートコードインジェクションの脆弱性をアプリケーションに入れてしまうでしょう。

予約キー

Laravelは内部で、flashセッションキーを使用しています。そのため、この名前のセッションアイテムを追加しないでください。

セッションの使用

HTTPリクエストのsessionメソッド、Sessionファサード、sessionヘルパ関数など、セッションに多くの手段でアクセス可能です。sessionヘルパを引数を指定せず実行すれば、セッションオブジェクト全体が取得できます。次のように使えます。

session()->regenerate();

セッションにアイテム保存

Session::put('key', 'value')

session(['key' => 'value']);

配列セッション値として保存

Session::push('user.teams', 'developers');

セッションからアイテム取得

$value = Session::get('key');

$value = session('key');

アイテムかデフォルト値の取得

$value = Session::get('key', 'default');

$value = Session::get('key', function() { return 'default'; });

アイテム取得後に削除

$value = Session::pull('key', 'default');

セッションから全データ取得

$data = Session::all();

アイテムの存在確認

if (Session::has('users'))
{
    //
}

セッションからアイテム削除

Session::forget('key');

セッションから全アイテム削除

Session::flush();

セッションIDの再生成

Session::regenerate();

フラッシュデーター

次のリクエストの間だけアイテムを保存しておきたいこともあります。Session::flashメソッドが使えます。

Session::flash('key', 'value');

現在のフラッシュデーターの寿命を次のリクエストまで延長

Session::reflash();

指定したフラッシュデーターの寿命を延長

Session::keep(['username', 'email']);

データベースセッション

databaseセッションを使用する場合、セッションに必要な項目を含んだテーブルを用意してください。以下にサンプルのSchema宣言を紹介します。

Schema::create('sessions', function($table)
{
    $table->string('id')->unique();
    $table->text('payload');
    $table->integer('last_activity');
});

もちろん、Artisanコマンドのsession:tableで、このマイグレーションを生成することも可能です!

php artisan session:table

composer dump-autoload

php artisan migrate

セッションドライバー

セッション「ドライバー」で、それぞれのリクエストのセッションデーターをどこに保存するかを定義します。Laravelでは、素晴らしいドライバーを始めから用意しています。

注目: 配列(array)ドライバーは、通常ユニットテストを実行するため使用されます。そのため、そのため、セッションデーターは保持されません。

ドキュメント章別ページ

Artisan CLI

ヘッダー項目移動

注目:アイコン:ページ内リンク設置(リンクがないヘッダーへの移動では、リンクがある以前のヘッダーのハッシュをURLへ付加します。

移動

クリックで即時移動します。

バージョン

設定

適用ボタンクリック後に、全項目まとめて適用されます。

カラーテーマ
和文指定 Pagination
和文指定 Scaffold
Largeスクリーン表示幅
インデント
本文フォント
コードフォント
フォント適用確認

フォントの指定フィールドから、フォーカスが外れると、当ブロックの内容に反映されます。EnglishのDisplayもPreviewしてください。

フォント設定時、表示に不具合が出た場合、当サイトのクッキーを削除してください。

バックスラッシュを含むインライン\Code\Blockの例です。

以下はコードブロックの例です。

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
    /**
     * ユーザに関連する電話レコードを取得
     */
    public function phone()
    {
        return $this->hasOne('App\Phone');
    }
}

設定を保存する前に、表示が乱れないか必ず確認してください。CSSによるフォントファミリー指定の知識がない場合は、フォントを変更しないほうが良いでしょう。

キーボード・ショートカット

オープン操作

PDC

ページ(章)移動の左オフキャンバスオープン

HA

ヘッダー移動モーダルオープン

MS

移動/設定の右オフキャンバスオープン

ヘッダー移動

T

最初のヘッダーへ移動

E

最後のヘッダーへ移動

NJ

次ヘッダー(H2〜H4)へ移動

BK

前ヘッダー(H2〜H4)へ移動

その他

?

このヘルプページ表示
閉じる