Django中Cookie搭配Session使用實(shí)踐
Cookie的作用
前面我們說(shuō)道Django實(shí)戰(zhàn)006:Cookie設(shè)置及跨域問(wèn)題處理,Cookie可以在瀏覽器端保存用戶數(shù)據(jù),當(dāng)用戶訪問(wèn)服務(wù)器時(shí)會(huì)提交Cookie給服務(wù)器,Cookie附加了當(dāng)前狀態(tài), 服務(wù)器可以通過(guò)Cookie來(lái)標(biāo)識(shí)用戶的登錄狀態(tài),起到簡(jiǎn)單的用戶身份識(shí)別和用戶信息記錄等作用。
Cookie登錄的實(shí)現(xiàn)過(guò)程
1.用戶通過(guò)form表單提交自己的用戶名和密碼,這通常是一個(gè)POST的 HTTP請(qǐng)求。
2.服務(wù)器拿到用戶的信息開(kāi)始驗(yàn)證用戶名與密碼,如果與數(shù)據(jù)庫(kù)匹配成功我們就返回200同時(shí)設(shè)置一個(gè)Set-Cookie拋給瀏覽器,通過(guò)為‘鍵'=‘值'形式 。
3.瀏覽器接收到服務(wù)器響應(yīng)返回的數(shù)據(jù)和Cookie,然后將Cookie存起來(lái),在開(kāi)發(fā)者application中可以查看到。
4.瀏覽器再次發(fā)送請(qǐng)求時(shí),將設(shè)置了‘鍵'=‘值'的Cookie再次拋給服務(wù)器,服務(wù)器通過(guò)Cookie的
字段判斷用戶已經(jīng)登錄,則根據(jù)需求處理用戶請(qǐng)求,否則返回400提示用戶先登錄。
Cookie的安全隱患
這就是Cookie的實(shí)現(xiàn)過(guò)程,這里有個(gè)很明顯的問(wèn)題就是服務(wù)器只要識(shí)別到正確的Cookie就會(huì)處理對(duì)應(yīng)的數(shù)據(jù),那么有心人只要想辦法截獲(很多HTTP客戶端軟件都可以發(fā)送任意的HTTP請(qǐng)求)你的Cookie就可以冒充用戶來(lái)訪問(wèn)該服務(wù)器并獲取到用戶的所有信息,這對(duì)用戶來(lái)說(shuō)會(huì)存在著極大的安全隱患。
Session的引進(jìn)
session和cookie功能差不多,同樣是用來(lái)記錄用戶信息和維持會(huì)話狀態(tài)的,但是session是依賴cookie的。session不同在于將用戶數(shù)據(jù)存儲(chǔ)在服務(wù)器端(用戶拿到session內(nèi)的具體內(nèi)容),Cookie則是將數(shù)據(jù)存儲(chǔ)在瀏覽器端,所以相對(duì)cookie來(lái)說(shuō),session相對(duì)安全多了,我們只需要在設(shè)置Cookie時(shí)附帶上session的id,當(dāng)用戶再次訪問(wèn)服務(wù)器時(shí)將session的id拋給服務(wù)器進(jìn)行效驗(yàn)。
Session的啟用
Django中使用session很簡(jiǎn)單,Django封裝了session
模塊,默認(rèn)在我們創(chuàng)建項(xiàng)目的時(shí)候就已經(jīng)啟用了,在數(shù)據(jù)庫(kù)中可以找到一個(gè)名為django_session的數(shù)據(jù)庫(kù)表,這個(gè)就是用來(lái)存放session數(shù)據(jù)的。
Session的使用
設(shè)置保存session數(shù)據(jù),通過(guò)reques.session['鍵']='值'的方式來(lái)設(shè)置指定存儲(chǔ)的session信息,通過(guò)瀏覽器訪問(wèn)該視圖就可以將session設(shè)置的信息以base64編碼存入到django_session數(shù)據(jù)庫(kù)表中。
讀取session數(shù)據(jù),同樣很簡(jiǎn)單通過(guò)request.session.get('鍵')來(lái)獲取對(duì)應(yīng)的值,通過(guò)該方法可以從django_session數(shù)據(jù)庫(kù)表中讀取到對(duì)應(yīng)鍵的值。
Session搭配Cookie使用
在cookie中傳入sessionid作為前端的存儲(chǔ)值,這里為了保證sessionid的唯一性,我最簡(jiǎn)單的方法是用uuid來(lái)生成隨機(jī)字符串,再在sessionid中設(shè)置session值,再給set_cookie設(shè)置個(gè)過(guò)期時(shí)間,這樣只要時(shí)間一到又會(huì)重新生成一個(gè)新的sessionid來(lái)(如果你覺(jué)得uuid4()還是會(huì)出現(xiàn)重復(fù)也可以自行定義)。
在瀏覽器端看到的就是一串隨機(jī)的字符串,當(dāng)用戶訪問(wèn)服務(wù)器時(shí)cookie會(huì)把sessionid拋給服務(wù)器,服務(wù)器驗(yàn)證sessionid對(duì)應(yīng)的值是否為django_session數(shù)據(jù)庫(kù)表中讀取到對(duì)應(yīng)鍵的值,如果是則執(zhí)行數(shù)據(jù)請(qǐng)求操作,否則返回400,告訴前端操作失敗。
到此這篇關(guān)于Django中Cookie搭配Session使用實(shí)踐的文章就介紹到這了,更多相關(guān)Django Cookie搭配Session內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Django cookie和session的應(yīng)用場(chǎng)景及如何使用
- django框架cookie和session用法實(shí)例詳解
- Django中的cookie和session
- Django組件cookie與session的具體使用
- Django框架會(huì)話技術(shù)實(shí)例分析【Cookie與Session】
- django框架之cookie/session的使用示例(小結(jié))
- django進(jìn)階之cookie和session的使用示例
- Django中的cookie與session操作實(shí)例代碼
- 深入探究Django中的Session與Cookie
相關(guān)文章
python發(fā)送郵件的實(shí)例代碼(支持html、圖片、附件)
python發(fā)送郵件的一些例子,有需要的朋友可以參考下2013-03-03基于python+pandoc實(shí)現(xiàn)html批量轉(zhuǎn)word
pandoc是一個(gè)強(qiáng)大的文檔格式轉(zhuǎn)換工具,支持豐富的格式轉(zhuǎn)換,并盡可能的保留原來(lái)的排版,號(hào)稱文檔格式轉(zhuǎn)換的瑞士軍刀,本文將給大家介紹一下使用python搭配pandoc實(shí)現(xiàn)html批量轉(zhuǎn)word,感興趣的朋友可以參考閱讀下2023-09-09Python跑循環(huán)時(shí)內(nèi)存泄露的解決方法
這篇文章主要介紹了Python跑循環(huán)時(shí)內(nèi)存泄露的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01python 正則表達(dá)式參數(shù)替換實(shí)例詳解
這篇文章主要介紹了python 正則表達(dá)式參數(shù)替換,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-01-01使用python數(shù)據(jù)清洗代碼實(shí)例
這篇文章主要介紹了使用python數(shù)據(jù)清洗代碼實(shí)例,分享一下近期用python做數(shù)據(jù)清洗匯總的相關(guān)代碼,這里我們用到的python包有pandas、numpy、os等,需要的朋友可以參考下2023-07-07Python線性點(diǎn)運(yùn)算數(shù)字圖像處理示例詳解
這篇文章主要為大家介紹了數(shù)字圖像處理基本運(yùn)算如何用Python詳細(xì)點(diǎn)運(yùn)算來(lái)處理數(shù)字圖像有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-09-09