session
創(chuàng)新互聯(lián)建站專注于涿鹿網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供涿鹿?fàn)I銷型網(wǎng)站建設(shè),涿鹿網(wǎng)站制作、涿鹿網(wǎng)頁設(shè)計(jì)、涿鹿網(wǎng)站官網(wǎng)定制、成都微信小程序服務(wù),打造涿鹿網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供涿鹿網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
session是什么?
是保存在服務(wù)器端的鍵值對
session必須依賴于Cookie
django中session做的事兒:
存session:
在服務(wù)端生成隨機(jī)字符串 生成一個(gè)和上面隨機(jī)字符串對應(yīng)的大字典,用來保存用戶的數(shù)據(jù) 隨機(jī)字符串當(dāng)成cookie返回給瀏覽器
取session:
從請求攜帶的Cookie里面找到隨機(jī)字符串 拿到隨機(jī)字符串取session中找到對應(yīng)的大字典 從打字段中根據(jù)key去取值
session 相較于Cookie的優(yōu)勢:
比Cookie能存的數(shù)據(jù)多 安全性好,數(shù)據(jù)都保存在服務(wù)器端
Cookie雖然在一定程度上解決了“保持狀態(tài)”的需求,但是由于Cookie本身最大支持4096字節(jié),以及Cookie本身保存在客戶端,可能被攔截或竊取,因此就需要有一種新的東西,它能支持更多的字節(jié),并且他保存在服務(wù)器,有較高的安全性。這就是Session。
問題來了,基于HTTP協(xié)議的無狀態(tài)特征,服務(wù)器根本就不知道訪問者是“誰”。那么上述的Cookie就起到橋接的作用。
我們可以給每個(gè)客戶端的Cookie分配一個(gè)唯一的id,這樣用戶在訪問時(shí),通過Cookie,服務(wù)器就知道來的人是“誰”。然后我們再根據(jù)不同的Cookie的id,在服務(wù)器上保存一段時(shí)間的私密資料,如“賬號(hào)密碼”等等。
總結(jié)而言:Cookie彌補(bǔ)了HTTP無狀態(tài)的不足,讓服務(wù)器知道來的人是“誰”;但是Cookie以文本的形式保存在本地,自身安全性較差;所以我們就通過Cookie識(shí)別不同的用戶,對應(yīng)的在Session里保存私密的信息以及超過4096字節(jié)的文本。
另外,上述所說的Cookie和Session其實(shí)是共通性的東西,不限于語言和框架。
# 獲取、設(shè)置、刪除Session中數(shù)據(jù) request.session['k1'] request.session.get('k1',None) request.session['k1'] = 123request.session.setdefault('k1',123) # 存在則不設(shè)置 del request.session['k1'] # 所有 鍵、值、鍵值對 request.session.keys() request.session.values() request.session.items() request.session.iterkeys() request.session.itervalues() request.session.iteritems() # 會(huì)話session的key request.session.session_key # 將所有Session失效日期小于當(dāng)前日期的數(shù)據(jù)刪除 request.session.clear_expired() # 檢查會(huì)話session的key在數(shù)據(jù)庫中是否存在 request.session.exists("session_key") # 刪除當(dāng)前會(huì)話的所有Session數(shù)據(jù) request.session.delete() # 刪除當(dāng)前的會(huì)話數(shù)據(jù)并刪除會(huì)話的Cookie。 request.session.flush() 這用于確保前面的會(huì)話數(shù)據(jù)不可以再次被用戶的瀏覽器訪問 例如,django.contrib.auth.logout() 函數(shù)中就會(huì)調(diào)用它。 # 設(shè)置會(huì)話Session和Cookie的超時(shí)時(shí)間 request.session.set_expiry(value) * 如果value是個(gè)整數(shù),session會(huì)在些秒數(shù)后失效。 * 如果value是個(gè)datatime或timedelta,session就會(huì)在這個(gè)時(shí)間后失效。 * 如果value是0,用戶關(guān)閉瀏覽器session就會(huì)失效。 * 如果value是None,session會(huì)依賴全局session失效策略。
from functools import wraps def check_login(func): @wraps(func) def inner(request,*args,**kwargs): next_url = request.get_full_path() if request.session.get("user"): return func(request,*args,**kwargs) else: return redirect("/login/?next={}".format(next_url)) return inner def login(request): if request.method == "POST": user = request.POST.get("user") pwd = request.POST.get("pwd") if user == 'john' and pwd == "john123": #設(shè)置session request.session["user"] = user #獲取跳到登錄頁面之前的URL next_url = request.GET.get("next") #如果有,就跳轉(zhuǎn)回登錄之前的URL if next_url: return redirect(next_url) #否則默認(rèn)跳轉(zhuǎn)到index頁面 else: return redirect("/index/") return render(request,"login.html") @check_login def logout(request): #刪除所有當(dāng)前請求相關(guān)的session requestsession.delete() return redirect("/login/") @check_login def index(request): current_user = request.session.get("user",None) return render(request,"index.html",{"user":current_user})
Django中默認(rèn)支持Session,其內(nèi)部提供了5種類型的Session供開發(fā)者使用。
1. 數(shù)據(jù)庫Session SESSION_ENGINE = 'django.contrib.sessions.backends.db' # 引擎(默認(rèn))2. 緩存Session SESSION_ENGINE = 'django.contrib.sessions.backends.cache' # 引擎 SESSION_CACHE_ALIAS = 'default' # 使用的緩存別名(默認(rèn)內(nèi)存緩存,也可以是memcache),此處別名依賴緩存的設(shè)置3. 文件Session SESSION_ENGINE = 'django.contrib.sessions.backends.file' # 引擎 SESSION_FILE_PATH = None # 緩存文件路徑,如果為None,則使用tempfile模塊獲取一個(gè)臨時(shí)地址tempfile.gettempdir() 4. 緩存+數(shù)據(jù)庫 SESSION_ENGINE = 'django.contrib.sessions.backends.cached_db' # 引擎5. 加密Cookie Session SESSION_ENGINE = 'django.contrib.sessions.backends.signed_cookies' # 引擎 其他公用設(shè)置項(xiàng): SESSION_COOKIE_NAME = "sessionid" # Session的cookie保存在瀏覽器上時(shí)的key,即:sessionid=隨機(jī)字符串(默認(rèn)) SESSION_COOKIE_PATH = "/" # Session的cookie保存的路徑(默認(rèn)) SESSION_COOKIE_DOMAIN = None # Session的cookie保存的域名(默認(rèn)) SESSION_COOKIE_SECURE = False # 是否Https傳輸cookie(默認(rèn)) SESSION_COOKIE_HTTPONLY = True # 是否Session的cookie只支持http傳輸(默認(rèn)) SESSION_COOKIE_AGE = 1209600 # Session的cookie失效日期(2周)(默認(rèn)) SESSION_EXPIRE_AT_BROWSER_CLOSE = False # 是否關(guān)閉瀏覽器使得Session過期(默認(rèn)) SESSION_SAVE_EVERY_REQUEST = False # 是否每次請求都保存Session,默認(rèn)修改之后才保存(默認(rèn))