溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Laravel操作session和cookie的方法是什么

發(fā)布時(shí)間:2023-02-10 09:09:56 來(lái)源:億速云 閱讀:83 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“Laravel操作session和cookie的方法是什么”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“Laravel操作session和cookie的方法是什么”吧!

一:操作session

1:session配置

Session 的配置文件存儲(chǔ)在config/session.php中,配置參數(shù)有:

(1):配置session驅(qū)動(dòng)

'driver' => env('SESSION_DRIVER', 'file'),//#這里表示先讀取.env文件的SESSION_DRIVER參數(shù)值,如果沒(méi)有使用file驅(qū)動(dòng)

laravel自帶的驅(qū)動(dòng)

  • file - 將 Session 保存在 指定文件地址 中。

  • cookie - Session 保存在安全加密的 Cookie 中。

  • database - Session 保存在關(guān)系型數(shù)據(jù)庫(kù)中。

  • memcached / redis - Sessions 保存在其中一個(gè)快速且基于緩存的存儲(chǔ)系統(tǒng)中。

  • array - Sessions 保存在 PHP 數(shù)組中,不會(huì)被持久化。

(2):配置失效時(shí)間

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

(3):使用file驅(qū)動(dòng)時(shí)session文件保存地址

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

(4):使用redis驅(qū)動(dòng)時(shí)指定 Session 使用哪個(gè) Redis 連接

'connection' => null,//不修改使用默認(rèn)的redis

(5):使用database驅(qū)動(dòng)時(shí)將session數(shù)據(jù)存入的數(shù)據(jù)庫(kù)名

'table' => 'sessions',

使用database驅(qū)動(dòng)時(shí),在目錄命令行執(zhí)行

php artisan session:table

這時(shí)候會(huì)在database/migrations目錄下生成一個(gè)創(chuàng)建session數(shù)據(jù)表的文件

/**
     * 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');
    }

然后執(zhí)行

php artisan migrate

這時(shí)候會(huì)在數(shù)據(jù)庫(kù)中生成一個(gè)sessions表,這個(gè)表就是保存session數(shù)據(jù)的表

2:設(shè)置session

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

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

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

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

3:獲取session

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

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

獲取指定session,不存在設(shè)置默認(rèn)值

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

(2):使用全局輔助函數(shù)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實(shí)例刪除session

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

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

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

5:重新生成 Session ID

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

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

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

session()->regenerate();

二:操作cookie

1:設(shè)置cookie

Cookie::queue('test', 'testValue', 10);//設(shè)置cookie,test值為testValue,設(shè)置cookie時(shí)長(zhǎng)10分鐘
Cookie::make('cookie_name', 'value', 10);//設(shè)置cookie,cookie_name值為value,設(shè)置cookie時(shí)長(zhǎng)10分鐘
Cookie::forever('key','value');//設(shè)置cookie,key值為value,永不過(guò)期

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

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

2:獲取cookie

Cookie::get('key');

3:刪除cookie

Cookie::forget('key');

到此,相信大家對(duì)“Laravel操作session和cookie的方法是什么”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI