Laravel操作session和cookie的教程詳解
目錄
- 一:操作session
- 1:session配置
- 2:設置session
- 3:獲取session
- 4:刪除session
- 5:重新生成 Session ID
- 二:操作cookie
- 1:設置cookie
- 2:獲取cookie
- 3:刪除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內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!
