Django操作session 的方法
session是存放在服務(wù)端的,在django中使用session必須要先在數(shù)據(jù)庫中創(chuàng)建django_session表,session相關(guān)信息都要依賴此表
獲取session
request.session[’status’]request.session.get(’status’)#一般用get,無此鍵返回None不報錯
設(shè)置session
#在使用session之前必須在數(shù)據(jù)庫創(chuàng)建相關(guān)的表(django_session)
#調(diào)用request.session首先會接收請求頭部的cookie是否有sessionid,進(jìn)行表查詢對比
#如果有重新生成一個sessionid進(jìn)行覆蓋更新記錄,并將隨機(jī)生成的sessionid添加到cookie返回前端
# 沒有則新建存進(jìn)表中的session_key,同時將字典信息加密自動存進(jìn)表中的session_data字段
request.session[’status’]=True # 存在自動覆蓋
request.session.setdefault(’k1’,123) # 存在則不設(shè)置
刪除session
request.session.flush()#刪除服務(wù)端的session,刪除當(dāng)前的會話數(shù)據(jù)并刪除會話的Cookie。
request.session.clear_expired()# 將所有Session失效日期小于當(dāng)前日期的數(shù)據(jù)刪除,將過期的刪除
del request.session[’k1’]#django-session表里面同步刪除
request.session.delete()# 刪除當(dāng)前會話的所有Session數(shù)據(jù)
更多session操作
# 所有 鍵、值、鍵值對
request.session.keys()
request.session.values()
request.session.items()
#獲取sessionid的值
session_key = request.session.session_key
#檢查會話session的key在數(shù)據(jù)庫中是否存在
request.session.exists('session_key') #session_key就是那個sessionid的值
# 設(shè)置會話Session和Cookie的超時時間
request.session.set_expiry(value)
* 如果value是個整數(shù),session會在些秒數(shù)后失效。
* 如果value是個datatime或timedelta,session就會在這個時間后失效。
* 如果value是0,用戶關(guān)閉瀏覽器session就會失效。
* 如果value是None,session會依賴全局session失效策略。
Session詳細(xì)流程解析
Django中的Session配置
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模塊獲取一個臨時地址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保存在瀏覽器上時的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))
總結(jié)
到此這篇關(guān)于Django操作session 的方法的文章就介紹到這了,更多相關(guān)django操作session 內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. JavaWeb Servlet中url-pattern的使用2. ASP中格式化時間短日期補(bǔ)0變兩位長日期的方法3. asp知識整理筆記4(問答模式)4. 怎樣才能用js生成xmldom對象,并且在firefox中也實(shí)現(xiàn)xml數(shù)據(jù)島?5. javascript xml xsl取值及數(shù)據(jù)修改第1/2頁6. ASP實(shí)現(xiàn)加法驗(yàn)證碼7. XML解析錯誤:未組織好 的解決辦法8. 小技巧處理div內(nèi)容溢出9. js的一些潛在規(guī)則使用分析10. ASP刪除img標(biāo)簽的style屬性只保留src的正則函數(shù)
