您好,登錄后才能下訂單哦!
小編給大家分享一下yii2中cookie為什么取不到,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
Yii2的Cookie主要是通過yii\web\Request和yii\web\Response進(jìn)行操作
通過\Yii::$app->response->getCookies()->add()添加Cookie
通過\Yii::$app->request->cookies讀取Cookie.
在js中創(chuàng)建的cookie,默認(rèn)用yii2中自帶的方法Yii::$app->request->cookies->get('abc')獲取不到,而用$_COOKIE['abc']又是能獲取到,則是以下原因照成的。
查看E:\myYiiDemo\vendor\yiisoft\yii2\web\Request.php中的1218行不難看出,使用yii2中的方法獲取cookie的時(shí)候,會(huì)讀取cookieValidationKey中的字串來解密(存cookie的時(shí)候也會(huì)用它來加密)。
由于js并沒有對cookie加密,所以這里解不開,自然獲取不到cookie了。
解決方法可以將enableCookieValidation設(shè)置為false,具體操作如下:
Yii::$app->request->enableCookieValidation = false; Yii::$app->request->cookies->get('abc');
溫馨提示:
用完后記得恢復(fù)回來(Yii::$app->request->enableCookieValidation = true;),否則可能影響下面的邏輯。
看完了這篇文章,相信你對“yii2中cookie為什么取不到”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。