Django中Cookie設(shè)置及跨域問題處理詳解
什么是Cookie(翻譯:曲奇餅干)
Cookie是存儲(chǔ)在瀏覽器中的一段純文本信息(簡單的說就是瀏覽器緩存),用來記錄用戶的使用情況并將其存儲(chǔ)在本地設(shè)備中,當(dāng)用戶訪問服務(wù)器時(shí)會(huì)將Cookie附帶上,服務(wù)端通過讀取Cookie的記錄,來維持用戶與服務(wù)器的會(huì)話狀態(tài)。
Cookie怎么來的
Cookie是由服務(wù)器生成的,通常以鍵值對的格式呈現(xiàn)(鍵值由服務(wù)器端開發(fā)者自行定義),當(dāng)用戶通過了瀏覽器訪問服務(wù)器時(shí),服務(wù)器會(huì)在返回?cái)?shù)據(jù)的時(shí)候把Cookie傳給瀏覽器(建議不要存儲(chǔ)敏感信息,因?yàn)闉g覽器可能被多人使用)。
為什么要用Cookie
Cookie是由HTTP服務(wù)器設(shè)置的,而HTTP協(xié)議是一種無狀態(tài)協(xié)議,瀏覽器與服務(wù)器使用Socket套接字進(jìn)行通信,當(dāng)服務(wù)器將請求結(jié)果返回給瀏覽器之后就會(huì)關(guān)閉當(dāng)前的Socket連接并釋放資源,所以每次請求數(shù)據(jù)都需要建立新的連接。 Cookie的出現(xiàn)彌補(bǔ)了這個(gè)缺點(diǎn),當(dāng)瀏覽器向服務(wù)器發(fā)送請求時(shí),會(huì)將瀏覽器中存儲(chǔ)的跟網(wǎng)站相關(guān)的所有Cookie信息提交給網(wǎng)站服務(wù)器,服務(wù)器通過Cookie中的信息來驗(yàn)證用戶身份和判斷HTTP傳輸狀態(tài),并將符合條件的數(shù)據(jù)返回給瀏覽器。
Cookie的特點(diǎn)
Cookie是基于作用域設(shè)計(jì)的,也就是說同一域名下只能訪問到當(dāng)前域名下的Cookie信息,無法訪問到其他域名的Cookie信息的。
怎么設(shè)置Cookie
Django可以通過HttpResponse來
響應(yīng)對象的set_cookie,設(shè)置好對應(yīng)的視圖和路由,只要通過瀏覽器訪問該路由,瀏覽器就會(huì)自動(dòng)獲取到set_cookie值并存入到本地(當(dāng)瀏覽器正在運(yùn)行時(shí)通常都存在內(nèi)存中,當(dāng)瀏覽器關(guān)閉時(shí)通常會(huì)存入硬盤中)。
Cookie常用參數(shù)
在設(shè)置Cookie時(shí)可以多參數(shù)定義,這個(gè)可以根據(jù)自己的需求來定義,最少要有key和value,其他可省略不填,方法是:response.set_cookie('鍵', '值')
。
key:鍵
value:值
max_age:多久后過期,時(shí)間為秒,默認(rèn)為None,臨時(shí)cookie設(shè)置即關(guān)閉瀏覽器就消失
expires:過期時(shí)間,具體時(shí)間
path:生效路徑,默認(rèn)‘/'
domain:生效的域名,你綁定的域名
secure:HTTPS傳輸時(shí)應(yīng)設(shè)置為true,默認(rèn)為false
httponly:值應(yīng)用于http傳輸,這時(shí)JavaScript無法獲取
怎么獲取Cookie
Django可以通過HttpResponse
請求對象的COOKIES
屬性來讀取Cookie,方法是:request.COOKIES.get('鍵'),這樣我們在瀏覽器訪問路由時(shí)就能直接獲取到之前設(shè)置好的Cookie了。
Cookie跨域問題處理
前面我們只是簡單的進(jìn)行了路由請求,那么結(jié)合到系統(tǒng)中來又會(huì)是怎樣的呢,我把Cookie帶入到項(xiàng)目中來(前后端分離模式),我們會(huì)發(fā)現(xiàn),同樣的代碼在前面始終無法獲取到Cookie值,這是怎么回事呢?前面有提到Cookie是基于安全域設(shè)計(jì)的,所以是不支持跨域處理的 ,那么我們怎么來實(shí)現(xiàn)跨域訪問呢。這里我們要采用的是“跨域資源共享”,一種可以讓瀏覽器獲得訪問不同源服務(wù)器指定資源的權(quán)限機(jī)制,通過它Axios在訪問服務(wù)器時(shí)能攜帶著Cookie回來。
首先需要axios能夠獲取到Cookie,出于安全考慮瀏覽器默認(rèn)是不支持獲取跨域Cookie的,所以這里我們需要對axios設(shè)置進(jìn)行下修改,將withCredentials屬性設(shè)置為true,即允許瀏覽器設(shè)置或獲取Cookie。設(shè)置方法直接在main.js中進(jìn)行全局設(shè)置,axios.defaults.withCredentials = true 。
當(dāng)服務(wù)器接收到請求后,會(huì)根據(jù)自己的跨域規(guī)則,決定是否同意這次請求,而這個(gè)規(guī)則在請求設(shè)置Cookie時(shí)就要給定,這里主要要設(shè)置Access-Control-Allow-Origin和Access-Control-Allow-Credentials屬性,Access-Control-Allow-Origin默認(rèn)為‘*',這里需要改成前端ip,Access-Control-Allow-Credentials改為true即可。
到此這篇關(guān)于Django中Cookie設(shè)置及跨域問題處理詳解的文章就介紹到這了,更多相關(guān)Django中Cookie設(shè)置及跨域內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Django中更新多個(gè)對象數(shù)據(jù)與刪除對象的方法
這篇文章主要介紹了Django中更新多個(gè)對象數(shù)據(jù)與刪除對象的方法,Django是Python重多各色框架中人氣最高的一個(gè),需要的朋友可以參考下2015-07-07python3兩數(shù)相加的實(shí)現(xiàn)示例
這篇文章主要介紹了python3兩數(shù)相加的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04python 批量修改 labelImg 生成的xml文件的方法
這篇文章主要介紹了python 批量修改 labelImg 生成的xml文件的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09正則化DropPath/drop_path用法示例(Python實(shí)現(xiàn))
DropPath 類似于Dropout,不同的是 Drop將深度學(xué)習(xí)模型中的多分支結(jié)構(gòu)隨機(jī)"失效",而Dropout是對神經(jīng)元隨機(jī)"失效"這篇文章主要給大家介紹了關(guān)于正則化DropPath/drop_path用法的相關(guān)資料,需要的朋友可以參考下2022-04-04