Django狀態(tài)保持搭配與存儲(chǔ)的實(shí)現(xiàn)_第1頁(yè)
Django狀態(tài)保持搭配與存儲(chǔ)的實(shí)現(xiàn)_第2頁(yè)
Django狀態(tài)保持搭配與存儲(chǔ)的實(shí)現(xiàn)_第3頁(yè)
Django狀態(tài)保持搭配與存儲(chǔ)的實(shí)現(xiàn)_第4頁(yè)
Django狀態(tài)保持搭配與存儲(chǔ)的實(shí)現(xiàn)_第5頁(yè)
已閱讀5頁(yè),還剩2頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

第Django狀態(tài)保持搭配與存儲(chǔ)的實(shí)現(xiàn)目錄引子為什么需要狀態(tài)保持如何實(shí)現(xiàn)狀態(tài)保持Cookie?Cookie的工作原理?Cookie的特點(diǎn)?Cookie與django服務(wù)器執(zhí)行流程配置Cookie讀取CookieSession?Session的特點(diǎn):?Session與django服務(wù)器執(zhí)行流程啟用Session?存儲(chǔ)數(shù)據(jù)庫(kù)?本地緩存?混合存儲(chǔ)session使用Session操作

引子

之前在學(xué)習(xí)Django時(shí),對(duì)狀態(tài)保持這個(gè)概念很模糊,不知道怎么去保持,通過(guò)什么去實(shí)現(xiàn)保持都不太清楚;稍微花了一點(diǎn)時(shí)間,把狀態(tài)保持的基本概念,使用cookie與session進(jìn)行存儲(chǔ)以及基本操作搭配圖文給理清了;閱讀本文大約需要15min

為什么需要狀態(tài)保持

因?yàn)橥ǔg覽器請(qǐng)求服務(wù)器是無(wú)狀態(tài)的,一次用戶請(qǐng)求時(shí),瀏覽器、服務(wù)器無(wú)法知道之前這個(gè)用戶做過(guò)什么,每次請(qǐng)求都是一次新的請(qǐng)求。

無(wú)狀態(tài)原因:瀏覽器與服務(wù)器是使用Socket套接字進(jìn)行通信的,服務(wù)器將請(qǐng)求結(jié)果返回給瀏覽器之后,會(huì)關(guān)閉當(dāng)前的Socket連接,而且服務(wù)器也會(huì)在處理頁(yè)面完畢之后銷毀頁(yè)面對(duì)象。

因此可以使用狀態(tài)保持來(lái)實(shí)現(xiàn)保持用戶瀏覽的狀態(tài),比如用戶是否登錄過(guò),瀏覽過(guò)哪些商品等

如何實(shí)現(xiàn)狀態(tài)保持

實(shí)現(xiàn)狀態(tài)保持主要有兩種方式:

在客戶端存儲(chǔ)信息使用Cookie在服務(wù)器端存儲(chǔ)信息使用Session

Cookie

?Cookie的工作原理

由于HTTP是一種無(wú)狀態(tài)的協(xié)議,服務(wù)器單從網(wǎng)絡(luò)連接上無(wú)從知道客戶身份。怎么辦呢?

就給客戶端們頒發(fā)一個(gè)通行證吧,每人一個(gè),無(wú)論誰(shuí)訪問(wèn)都必須攜帶自己通行證。這樣服務(wù)器就能從通行證上確認(rèn)客戶身份了。

?Cookie的特點(diǎn)

Cookie是由服務(wù)器生成,存儲(chǔ)在瀏覽器端的一小段文本信息,以鍵值對(duì)方式進(jìn)行存儲(chǔ)。通過(guò)瀏覽器訪問(wèn)一個(gè)網(wǎng)站時(shí),會(huì)將本地存儲(chǔ)的跟網(wǎng)站相關(guān)的所有cookie信息發(fā)送給該網(wǎng)站的服務(wù)器。Cookie是基于域名安全的。Cookie是有過(guò)期時(shí)間的,如果不指定,默認(rèn)關(guān)閉瀏覽器之后cookie就會(huì)過(guò)期。

?Cookie與django服務(wù)器執(zhí)行流程

配置Cookie

通過(guò)HttpResponse對(duì)象中的set_cookie方法來(lái)設(shè)置cookie。

HttpResponsse.set_cookit(sookie名,value=cookie值,max_age=cookie有效期)

寫法:設(shè)置存儲(chǔ)的鍵值,設(shè)置存儲(chǔ)事件

defcookie(request):

response=HttpResponse('ok')

response.set_cookie('make','Golang')#臨時(shí)cookie

response.set_cookie('luxor','PHP',max_age=3600)#有效期一小時(shí)

#max_age單位為秒,默認(rèn)為None.如果是臨時(shí)cookie,可將max_age設(shè)置為None.

讀取Cookie

可以通過(guò)HttpResponse對(duì)象的COOKIES屬性來(lái)讀取本次請(qǐng)求攜帶的cookie值。request.COOKIES為字典類型。

defcookie(request):

cookie1=request.COOKIES.get('make')

print(cookie1)

returnHttpResponse('OK')

Session

Django完全支持也匿名會(huì)話,簡(jiǎn)單說(shuō)就是使用跨網(wǎng)頁(yè)之間可以進(jìn)行通訊,比如顯示用戶名,用戶是否已經(jīng)發(fā)表評(píng)論。session框架讓你存儲(chǔ)和獲取訪問(wèn)者的數(shù)據(jù)信息,這些信息保存在服務(wù)器上(默認(rèn)是數(shù)據(jù)庫(kù)中),以cookies的方式發(fā)送和獲取一個(gè)包含sessionID的值,并不是用cookies傳遞數(shù)據(jù)本身。

?Session的特點(diǎn):

在服務(wù)器端進(jìn)行狀態(tài)保持的方案就是Session。session是以鍵值對(duì)進(jìn)行存儲(chǔ)的。session依賴于cookie。session也是有過(guò)期時(shí)間,如果不指定,默認(rèn)兩周就會(huì)過(guò)期。

?Session與django服務(wù)器執(zhí)行流程

啟用Session

編輯settings.py中的一些配置

MIDDLEWARE_CLASSES確保其中包含以下內(nèi)容

'django.contrib.sessions.middleware.SessionMiddleware',

?存儲(chǔ)數(shù)據(jù)庫(kù)

存儲(chǔ)在數(shù)據(jù)庫(kù)中,如下設(shè)置可以寫,也可以不寫,這是默認(rèn)存儲(chǔ)方式。

SESSION_ENGINE='django.contrib.sessions.backends.db'

如果存儲(chǔ)在數(shù)據(jù)庫(kù)中,需要在項(xiàng)INSTALLED_APPS中安裝Session應(yīng)用。

'django.contrib.sessions',

這些是默認(rèn)啟用的。如果你不用的話,也可以關(guān)掉這個(gè)以節(jié)省一點(diǎn)服務(wù)器的開(kāi)銷。

數(shù)據(jù)庫(kù)中的表如圖所示

由表結(jié)構(gòu)可知,操作Session包括三個(gè)數(shù)據(jù):鍵,值,過(guò)期時(shí)間。

?本地緩存

存儲(chǔ)在本機(jī)內(nèi)存中,如果丟失則不能找回,比數(shù)據(jù)庫(kù)的方式讀寫更快。

SESSION_ENGINE='django.contrib.sessions.backends.cache'

?混合存儲(chǔ)

優(yōu)先從本機(jī)內(nèi)存中存取,如果沒(méi)有則從數(shù)據(jù)庫(kù)中存取。

SESSION_ENGINE='django.contrib.sessions.backends.cached_db'

session使用

創(chuàng)建模擬登錄視圖

deftestsession(request):

#更新數(shù)據(jù)庫(kù)的session數(shù)據(jù)

request.session['name']='Shrimps'

request.session['age']=22

request.session['userid']=1024

returnHttpResponse('Good')創(chuàng)建模擬主頁(yè)視圖

fromdjango.httpimportHttpResponse

deftestIndex(request):

#查詢主頁(yè)的數(shù)據(jù)

userid=request.session.get('userid')

name=request.session.get('name')

ifuserid:

print('登陸過(guò)')

returnHttpResponse(f'Hello-{name}')

else:

print('未登錄')

returnHttpResponse('未登錄')登錄后訪問(wèn)主頁(yè)

在這里我是定義時(shí)間事件所以才會(huì)顯示晚上好

#代碼如下-(在returnHttpResponse('Good')之前執(zhí)行)

#判斷當(dāng)前時(shí)間

now_time=datetime.datetime.now().strftime('%H')

now_time=int(now_time)

ifnow_time12andnow_time18:

now_time='下午好'

elifnow_time12:

now_time='早上好'

else:

now_time='晚上好'

Session操作

通過(guò)HttpRequest對(duì)象的session屬性進(jìn)行會(huì)話的讀寫操作。

1)以鍵值對(duì)的格式寫session。

request.session['鍵']=值

2)根據(jù)鍵讀取值。

request.session.get('鍵',默認(rèn)值)

3)清除所有session,在存儲(chǔ)中刪除值部分。

request.session.clear()

4)清除session數(shù)據(jù),在存儲(chǔ)中刪除session的整條數(shù)據(jù)。

request.session.flush()

5)刪除session中的指定鍵及值,在存儲(chǔ)中只刪除某個(gè)鍵及對(duì)應(yīng)的值。

delrequest.session['鍵']

6)設(shè)置session的有效期

request.session.set_expir

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論