您好,登錄后才能下訂單哦!
本篇內容主要講解“Laravel操作session和cookie的方法是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Laravel操作session和cookie的方法是什么”吧!
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數據的表
(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數組數據中追加數據
(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');
(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();
(1):使用Request實例重新生成 Session ID
$request->session()->regenerate();
(2):使用全局輔助函數session重新生成 Session ID
session()->regenerate();
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);
Cookie::get('key');
Cookie::forget('key');
到此,相信大家對“Laravel操作session和cookie的方法是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。