Laravel操作session和cookie的教程詳解

一:操作session

1:session配置

Session 的配置文件存儲在config/session.php中,配置參數有:

(1):配置session驅動

'driver' => env('SESSION_DRIVER', 'file'),//#這裡表示先讀取.env文件的SESSION_DRIVER參數值,如果沒有使用file驅動

laravel自帶的驅動

  • file – 將 Session 保存在 指定文件地址 中。
  • cookie – Session 保存在安全加密的 Cookie 中。
  • database – Session 保存在關系型數據庫中。
  • memcached / redis – Sessions 保存在其中一個快速且基於緩存的存儲系統中。
  • array – Sessions 保存在 PHP 數組中,不會被持久化。

(2):配置失效時間

'lifetime' => env('SESSION_LIFETIME', 120),

(3):使用file驅動時session文件保存地址

'files' => storage_path('framework/sessions'),

(4):使用redis驅動時指定 Session 使用哪個 Redis 連接

'connection' => null,//不修改使用默認的redis

(5):使用database驅動時將session數據存入的數據庫名

'table' => 'sessions',

使用database驅動時,在目錄命令行執行

php artisan session:table

這時候會在database/migrations目錄下生成一個創建session數據表的文件

/**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('sessions', function (Blueprint $table) {
            $table->string('id')->unique();
            $table->unsignedBigInteger('user_id')->nullable();
            $table->string('ip_address', 45)->nullable();
            $table->text('user_agent')->nullable();
            $table->text('payload');
            $table->integer('last_activity');
        });
    }
 
    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('sessions');
    }

然後執行

php artisan migrate

這時候會在數據庫中生成一個sessions表,這個表就是保存session數據的表

2:設置session

(1):使用Request實例設置session

$request->session()->put('key', 'value');//設置session
$request->session()->push('arr','item');//session數組數據中追加數據

(2):使用全局輔助函數session設置

session(['key' => 'value']);//設置session
session()->push('arr','item');//session數組數據中追加數據

3:獲取session

(1):使用Request實例獲取session

$data = $request->session()->all();//獲取所有session
$value = $request->session()->get('key');//獲取指定session

獲取指定session,不存在設置默認值

$value = $request->session()->get('key', 'default');
$value = $request->session()->get('key', function () {
    return 'default';
});
//確定 Session 中是否存在某個值,該值存在且不為 null,那麼 has 方法會返回 true
if ($request->session()->has('key')) {
    //
}
//確定 Session 中是否存在某個值,即使其值為 null,返回 true
if ($request->session()->exists('key')) {
    //
}

(2):使用全局輔助函數session獲取

$value = session('key');
$value = session('key', 'default');
$value = session()->get('key')
$value = session()->get('key','default')
session()->has('key');
session()->exists('key');

4:刪除session

(1):使用Request實例刪除session

//獲取到session數據然後刪除session
$value = $request->session()->pull('key', 'default');
//刪除指定session
$request->session()->forget('key');
//刪除所有session
$request->session()->flush();

(2):使用全局輔助函數session刪除

//刪除指定session
session()->forget('name');
//清空所有session
session()->flush();

5:重新生成 Session ID

(1):使用Request實例重新生成 Session ID

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

(2):使用全局輔助函數session重新生成 Session ID

session()->regenerate();

二:操作cookie

1:設置cookie

Cookie::queue('test', 'testValue', 10);//設置cookie,test值為testValue,設置cookie時長10分鐘
Cookie::make('cookie_name', 'value', 10);//設置cookie,cookie_name值為value,設置cookie時長10分鐘
Cookie::forever('key','value');//設置cookie,key值為value,永不過期

註意:如果使用Cookie::make()或Cookie::forever()方法設置cookie的話,渲染視圖時不能直接使用:

return \response()->view('index',$data)->withCookie($cookie);

2:獲取cookie

Cookie::get('key');

3:刪除cookie

Cookie::forget('key');

到此這篇關於Laravel操作session和cookie的教程詳解的文章就介紹到這瞭,更多相關Laravel操作session cookie內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: