Django 5種類型Session使用方法解析
介紹
Session:在計算機中,尤其是在網(wǎng)絡應用中,稱為“會話控制”。Session 對象存儲特定用戶會話所需的屬性及配置信息。這樣,當用戶在應用程序的 Web 頁之間跳轉(zhuǎn)時,存儲在 Session 對象中的變量將不會丟失,而是在整個用戶會話中一直存在下去。
當用戶請求來自應用程序的 Web 頁時,如果該用戶還沒有會話,則 Web 服務器將自動創(chuàng)建一個 Session 對象。當會話過期或被放棄后,服務器將終止該會話。Session 對象最常見的一個用法就是存儲用戶的首選項。
session是基于cookie完成的,當用戶打開瀏覽器,去訪問服務器的時候,服務器會為每個用戶的瀏覽器創(chuàng)建一個會話對象(session對象),并且為每個session對象創(chuàng)建一個Jsessionid號。當session對象創(chuàng)建成功后,會以cookie的方式將這個Jsessionid號回寫給瀏覽器,當用戶再次進行訪問服務器時,及帶了具有Jsessionid號的cookie數(shù)據(jù)來一起訪問服務器,服務器通過不同session的 Jsessionid號來找出與其相關(guān)聯(lián)的session對象,通過不同的session對象來為不同的用戶服務。
使用
Django中默認支持Session,其內(nèi)部提供了5種類型的Session供開發(fā)者使用:
數(shù)據(jù)庫(默認) 緩存 文件 緩存+數(shù)據(jù)庫 加密cookie數(shù)據(jù)庫Session
Django默認支持Session,并且默認是將Session數(shù)據(jù)存儲在數(shù)據(jù)庫中,即:django_session 表中。 a. 配置 settings.py SESSION_ENGINE = ’django.contrib.sessions.backends.db’ # 引擎(默認) SESSION_COOKIE_NAME = 'sessionid' # Session的cookie保存在瀏覽器上時的key,即:sessionid=隨機字符串(默認) SESSION_COOKIE_PATH = '/'# Session的cookie保存的路徑(默認) SESSION_COOKIE_DOMAIN = None # Session的cookie保存的域名(默認) SESSION_COOKIE_SECURE = False # 是否Https傳輸cookie(默認) SESSION_COOKIE_HTTPONLY = True # 是否Session的cookie只支持http傳輸(默認) SESSION_COOKIE_AGE = 1209600 # Session的cookie失效日期(2周)(默認) SESSION_EXPIRE_AT_BROWSER_CLOSE = False # 是否關(guān)閉瀏覽器使得Session過期(默認) SESSION_SAVE_EVERY_REQUEST = False # 是否每次請求都保存Session,默認修改之后才保存(默認) b. 使用 def index(request): # 獲取、設置、刪除Session中數(shù)據(jù) request.session[’k1’] request.session.get(’k1’,None) request.session[’k1’] = 123 request.session.setdefault(’k1’,123) # 存在則不設置 del request.session[’k1’] # 所有 鍵、值、鍵值對 request.session.keys() request.session.values() request.session.items() # 3.0無下面3個方法 request.session.iterkeys() request.session.itervalues() request.session.iteritems() # 用戶session的隨機字符串 request.session.session_key # 將所有Session失效日期小于當前日期的數(shù)據(jù)刪除 request.session.clear_expired() # 檢查 用戶session的隨機字符串 在數(shù)據(jù)庫中是否 request.session.exists('session_key') # 刪除當前用戶的所有Session數(shù)據(jù) request.session.delete('session_key') request.session.delete() request.session.flush() request.session.set_expiry(value) * 如果value是個整數(shù),session會在些秒數(shù)后失效。 * 如果value是個datatime或timedelta,session就會在這個時間后失效。 * 如果value是0,用戶關(guān)閉瀏覽器session就會失效。 * 如果value是None,session會依賴全局session失效策略。
緩存Session
a. 配置 settings.py
SESSION_ENGINE = ’django.contrib.sessions.backends.cache’ # 引擎SESSION_CACHE_ALIAS = ’default’ # 使用的緩存別名(默認內(nèi)存緩存,也可以是memcache),此處別名依賴緩存的設置SESSION_COOKIE_NAME = 'sessionid' # Session的cookie保存在瀏覽器上時的key,即:sessionid=隨機字符串SESSION_COOKIE_PATH = '/' # Session的cookie保存的路徑SESSION_COOKIE_DOMAIN = None # Session的cookie保存的域名SESSION_COOKIE_SECURE = False # 是否Https傳輸cookieSESSION_COOKIE_HTTPONLY = True # 是否Session的cookie只支持http傳輸SESSION_COOKIE_AGE = 1209600 # Session的cookie失效日期(2周)SESSION_EXPIRE_AT_BROWSER_CLOSE = False # 是否關(guān)閉瀏覽器使得Session過期SESSION_SAVE_EVERY_REQUEST = False # 是否每次請求都保存Session,默認修改之后才保存
b. 使用
同上
文件Session
a. 配置 settings.py
SESSION_ENGINE = ’django.contrib.sessions.backends.file’ # 引擎SESSION_FILE_PATH = None # 緩存文件路徑,如果為None,則使用tempfile模塊獲取一個臨時地址tempfile.gettempdir() #
如:/var/folders/d3/j9tj0gz93dg06bmwxmhh6_xm0000gn/T
SESSION_COOKIE_NAME = 'sessionid' # Session的cookie保存在瀏覽器上時的key,即:sessionid=隨機字符串SESSION_COOKIE_PATH = '/' # Session的cookie保存的路徑SESSION_COOKIE_DOMAIN = None # Session的cookie保存的域名SESSION_COOKIE_SECURE = False # 是否Https傳輸cookieSESSION_COOKIE_HTTPONLY = True # 是否Session的cookie只支持http傳輸SESSION_COOKIE_AGE = 1209600 # Session的cookie失效日期(2周)SESSION_EXPIRE_AT_BROWSER_CLOSE = False # 是否關(guān)閉瀏覽器使得Session過期SESSION_SAVE_EVERY_REQUEST = False # 是否每次請求都保存Session,默認修改之后才保存
b. 使用
同上
緩存+數(shù)據(jù)庫Session
數(shù)據(jù)庫用于做持久化,緩存用于提高效率
a. 配置 settings.py
SESSION_ENGINE = ’django.contrib.sessions.backends.cached_db’ # 引擎
b. 使用
同上
加密cookie Session
a. 配置 settings.py
SESSION_ENGINE = ’django.contrib.sessions.backends.signed_cookies’ # 引擎
b. 使用
同上
登錄狀態(tài)驗證
def login_status(func): def warp(request,*args,**kwargs): user = request.session.get('username') if user: kwargs['username'] = user return func(request,*args,**kwargs) return redirect(login) return warp
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. phpstudy apache開啟ssi使用詳解2. django創(chuàng)建css文件夾的具體方法3. .NET SkiaSharp 生成二維碼驗證碼及指定區(qū)域截取方法實現(xiàn)4. docker容器調(diào)用yum報錯的解決辦法5. 存儲于xml中需要的HTML轉(zhuǎn)義代碼6. CentOS郵件服務器搭建系列—— POP / IMAP 服務器的構(gòu)建( Dovecot )7. IntelliJ IDEA創(chuàng)建web項目的方法8. 原生JS實現(xiàn)記憶翻牌游戲9. ASP中實現(xiàn)字符部位類似.NET里String對象的PadLeft和PadRight函數(shù)10. javascript xml xsl取值及數(shù)據(jù)修改第1/2頁
