溫馨提示×

溫馨提示×

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

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

laravel中如何獲取cookie

發(fā)布時間:2020-12-16 10:52:57 來源:億速云 閱讀:810 作者:小新 欄目:編程語言

小編給大家分享一下laravel中如何獲取cookie,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

COOKIE

laravel在底層會對cookie值進(jìn)行加密,并且使用授權(quán)碼進(jìn)行簽名。所以,如果客戶端修改了cookie值,那么就會失效。這樣,我們就不用擔(dān)心cookie偽造問題。

設(shè)置cookie值

設(shè)置cookie值會用到laravel響應(yīng)(Response)的知識,這里簡單帶過。

可以使用cookie函數(shù)來創(chuàng)建cookie,然后再通過response函數(shù)將cookie返回給客戶端:

// cookie($name, $value, $minutes, $path, $domain, false, ...);
$cookie = cookie('username', 'php.cn', 3600);
return response('hello laravel')->cookie($cookie);

除了使用cookie函數(shù)外,還可以使用響應(yīng)實(shí)例的cookie方法設(shè)置并返回。該方法和cookie函數(shù)的參數(shù)是一致的。

return response('Hello World')->cookie(
    'name', 'php.cn', 3600
);

獲取cookie值

獲取cookie值可以由兩種方法,下面演示這兩種方法:

use Illuminate\Http\Request;
$value = $request->cookie('name');
// 或
use Illuminate\Support\Facades\Cookie;
$value = Cookie::get('name');

獲取上傳的文件

laravel框架獲取上傳的文件及保持文件非常的簡單。

獲取上傳的文件有兩種方法,使用file方法或動態(tài)屬性方法。該方法返回Illuminate\Http\UploadedFile實(shí)例。

$logo = $request->file('logo');
// or
$logo = $request->logo;

當(dāng)然可在獲取文件前判斷該文件是否存在,這里使用hasFile方法:

if ($request->hasFile('logo')) {
    $logo = $request->file('logo');
}

request請求實(shí)例還能對上傳的文件進(jìn)行驗(yàn)證,我們非常推薦在保存文件前進(jìn)行此操作:

if ($request->file('logo')->isValid()) {
    //
}

uploadFile實(shí)例有許多方法,可以獲取上傳文件的零時保存路徑、擴(kuò)展名等信息。下面演示獲取文件類型后綴

$logo = $request->file('logo');
$logo->path();  // png

最后,將如何保存文件,保存文件使用store方法,該方法的有兩個參數(shù),第一個參數(shù)填寫保存文件的路徑,第二個參數(shù)填寫文件保存在哪個主目錄中(或第三方平臺里)。laravel會自動生成一個唯一ID作為文件名。該信息在配置文件config/filesystems.php中,如下:

'disks' => [
    'local' => [
        'driver' => 'local',
        'root' => storage_path('app'),
    ],
    'public' => [
        'driver' => 'local',
        'root' => storage_path('app/public'),
        'url' => env('APP_URL').'/storage',
        'visibility' => 'public',
    ],
    's3' => [
        'driver' => 's3',
        'key' => env('AWS_ACCESS_KEY_ID'),
        'secret' => env('AWS_SECRET_ACCESS_KEY'),
        'region' => env('AWS_DEFAULT_REGION'),
        'bucket' => env('AWS_BUCKET'),
        'url' => env('AWS_URL'),
        'endpoint' => env('AWS_ENDPOINT'),
    ],
],

如果想自己設(shè)置保存問價文件的文件名,需要使用storeAs方法,該方法的第二個參數(shù)是要設(shè)置的文件名。

$request->file('logo')->storeAs('img/logo', '1.png');

最后,貼出一個完整的文件上傳的代碼示例:

html代碼如下:

<form method="post" action="/index?a=32" enctype="multipart/form-data">
    @csrf
    <input type="file" name="logo" >
    <input type="submit" value="sub" />
</form>

保存文件代碼如下:

if ($request->hasFile('logo')) {
    $logo = $request->file('logo');
    if ($logo->isValid()) {
        $ext = $logo->extension();
        $fileName = date('YmdHis') . mt_rand(10000,99999);
        $path = $logo->storeAs('img/logo', $fileName . '.' . $ext);
        dump($path); //"img/logo/2020121413351718218.png"
    }
}

以上是“l(fā)aravel中如何獲取cookie”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

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

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

AI