您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Django狀態(tài)保持搭配與存儲(chǔ)如何實(shí)現(xiàn)”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Django狀態(tài)保持搭配與存儲(chǔ)如何實(shí)現(xiàn)”吧!
因?yàn)橥ǔg覽器請(qǐng)求服務(wù)器是 無狀態(tài) 的,一次用戶請(qǐng)求時(shí),瀏覽器、服務(wù)器無法知道之前這個(gè)用戶做過什么,每次請(qǐng)求都是一次新的請(qǐng)求。
無狀態(tài)原因:瀏覽器與服務(wù)器是使用Socket套接字進(jìn)行通信的,服務(wù)器將請(qǐng)求結(jié)果返回給瀏覽器之后,會(huì)關(guān)閉當(dāng)前的Socket連接,而且服務(wù)器也會(huì)在處理頁(yè)面完畢之后銷毀頁(yè)面對(duì)象。
因此可以使用狀態(tài)保持來實(shí)現(xiàn)保持用戶瀏覽的狀態(tài),比如用戶是否登錄過,瀏覽過哪些商品等
實(shí)現(xiàn)狀態(tài)保持主要有兩種方式:
在客戶端存儲(chǔ)信息使用Cookie
在服務(wù)器端存儲(chǔ)信息使用Session
由于HTTP是一種無狀態(tài)的協(xié)議,服務(wù)器單從網(wǎng)絡(luò)連接上無從知道客戶身份。怎么辦呢?
就給客戶端們頒發(fā)一個(gè)通行證吧,每人一個(gè),無論誰(shuí)訪問都必須攜帶自己通行證。這樣服務(wù)器就能從通行證上確認(rèn)客戶身份了。
Cookie是由服務(wù)器生成,存儲(chǔ)在瀏覽器端的一小段文本信息,以鍵值對(duì)方式進(jìn)行存儲(chǔ)。
通過瀏覽器訪問一個(gè)網(wǎng)站時(shí),會(huì)將本地存儲(chǔ)的跟網(wǎng)站相關(guān)的所有cookie信息發(fā)送給該網(wǎng)站的服務(wù)器。
Cookie是基于域名安全的。
Cookie是有過期時(shí)間的,如果不指定,默認(rèn)關(guān)閉瀏覽器之后cookie就會(huì)過期。
通過 HttpResponse
對(duì)象中的 set_cookie 方法來設(shè)置cookie。
HttpResponsse.set_cookit(sookie名, value=cookie值, max_age=cookie有效期)
寫法: 設(shè)置存儲(chǔ)的鍵值,設(shè)置存儲(chǔ)事件
def cookie(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.
可以通過 HttpResponse 對(duì)象的 COOKIES 屬性來讀取本次請(qǐng)求攜帶的cookie值。request.COOKIES為字典類型。
def cookie(request): cookie1 = request.COOKIES.get('make') print(cookie1) return HttpResponse('OK')
Django完全支持也匿名會(huì)話,簡(jiǎn)單說就是使用跨網(wǎng)頁(yè)之間可以進(jìn)行通訊,比如顯示用戶名,用戶是否已經(jīng)發(fā)表評(píng)論。session框架讓你 存儲(chǔ)和獲取訪問者的數(shù)據(jù)信息 ,這些信息保存在服務(wù)器上(默認(rèn)是數(shù)據(jù)庫(kù)中),以 cookies 的方式發(fā)送和獲取一個(gè)包含 session ID的值,并不是用cookies傳遞數(shù)據(jù)本身。
在服務(wù)器端進(jìn)行狀態(tài)保持的方案就是Session。
session是以鍵值對(duì)進(jìn)行存儲(chǔ)的。
session依賴于cookie。
session也是有過期時(shí)間,如果不指定,默認(rèn)兩周就會(huì)過期。
編輯 settings.py
中的一些配置
MIDDLEWARE_CLASSES 確保其中包含以下內(nèi)容
'django.contrib.sessions.middleware.SessionMiddleware',
存儲(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ù)器的開銷。
數(shù)據(jù)庫(kù)中的表如圖所示
由表結(jié)構(gòu)可知,操作Session包括三個(gè)數(shù)據(jù):鍵,值,過期時(shí)間。
存儲(chǔ)在本機(jī)內(nèi)存中,如果丟失則不能找回,比數(shù)據(jù)庫(kù)的方式讀寫更快。
SESSION_ENGINE='django.contrib.sessions.backends.cache'
優(yōu)先從本機(jī)內(nèi)存中存取,如果沒有則從數(shù)據(jù)庫(kù)中存取。
SESSION_ENGINE='django.contrib.sessions.backends.cached_db'
創(chuàng)建模擬登錄視圖
def testsession(request): # 更新數(shù)據(jù)庫(kù)的session數(shù)據(jù) request.session['name'] = 'Shrimps' request.session['age'] = 22 request.session['userid'] = 1024 return HttpResponse('Good')
創(chuàng)建模擬主頁(yè)視圖
from django.http import HttpResponse def testIndex(request): # 查詢主頁(yè)的數(shù)據(jù) userid = request.session.get('userid') name = request.session.get('name') if userid: print('登陸過') return HttpResponse(f'Hello - {name} ') else: print('未登錄') return HttpResponse('未登錄')
登錄后訪問主頁(yè)
在這里我是定義時(shí)間事件 所以才會(huì)顯示晚上好
# 代碼如下 - (在 return HttpResponse('Good') 之前執(zhí)行) # 判斷當(dāng)前時(shí)間 now_time = datetime.datetime.now().strftime('%H') now_time = int(now_time) if now_time > 12 and now_time < 18: now_time = '下午好' elif now_time < 12: now_time = '早上好' else: now_time = '晚上好'
通過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)的值。
del request.session['鍵']
6)設(shè)置session的有效期
request.session.set_expiry(value)
value規(guī)則:
如果value是一個(gè)整數(shù),session將在value秒沒有活動(dòng)后過期。
如果value為0,那么用戶 session的Cookie將在用戶的瀏覽器關(guān)閉時(shí)過期。
如果value為None,那么session有效期將采用系統(tǒng)默認(rèn)值, 默認(rèn)為兩周,可以通過在 settings.py
中設(shè)置SESSION_COOKIE_AGE來設(shè)置全局默認(rèn)值。
到此,相信大家對(duì)“Django狀態(tài)保持搭配與存儲(chǔ)如何實(shí)現(xiàn)”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。