Django操作session


session是存放在服務端的,在django中使用session必須要先在數據庫中創建django_session表,session相關信息都要依賴此表

獲取session

request.session['status']

request.session.get('status')#一般用get,無此鍵返回None不報錯

設置session

#在使用session之前必須在數據庫創建相關的表(django_session)

#調用request.session首先會接收請求頭部的cookie是否有sessionid,進行表查詢對比

#如果有重新生成一個sessionid進行覆蓋更新記錄,並將隨機生成的sessionid添加到cookie返回前端

# 沒有則新建存進表中的session_key,同時將字典信息加密自動存進表中的session_data字段

request.session['status']=True  # 存在自動覆蓋

 

request.session.setdefault('k1',123) # 存在則不設置

 

刪除session

request.session.flush()#刪除服務端的session,刪除當前的會話數據並刪除會話的Cookie

 

request.session.clear_expired()# 將所有Session失效日期小於當前日期的數據刪除,將過期的刪除

 

del request.session['k1']#django-session表里面同步刪除

 

request.session.delete()# 刪除當前會話的所有Session數據

 

 

更多session操作 

# 所有 鍵、值、鍵值對

request.session.keys()

request.session.values()

request.session.items()

 

#獲取sessionid的值

session_key = request.session.session_key 

 

#檢查會話sessionkey在數據庫中是否存在

request.session.exists("session_key") #session_key就是那個sessionid的值

 

# 設置會話SessionCookie的超時時間

request.session.set_expiry(value)

    * 如果value是個整數,session會在些秒數后失效。

    * 如果value是個datatimetimedeltasession就會在這個時間后失效。

    * 如果value0,用戶關閉瀏覽器session就會失效。

    * 如果valueNone,session會依賴全局session失效策略。

 

Session詳細流程解析

 

 

 

Django中的Session配置

Django中默認支持Session,其內部提供了5種類型的Session供開發者使用。

1. 數據庫Session

SESSION_ENGINE = 'django.contrib.sessions.backends.db'   # 引擎(默認)

 

2. 緩存Session

SESSION_ENGINE = 'django.contrib.sessions.backends.cache'  # 引擎

SESSION_CACHE_ALIAS = 'default'                            # 使用的緩存別名(默認內存緩存,也可以是memcache),此處別名依賴緩存的設置

 

3. 文件Session

SESSION_ENGINE = 'django.contrib.sessions.backends.file'    # 引擎

SESSION_FILE_PATH = None                                    # 緩存文件路徑,如果為None,則使用tempfile模塊獲取一個臨時地址tempfile.gettempdir()

 

4. 緩存+數據庫

SESSION_ENGINE = 'django.contrib.sessions.backends.cached_db'        # 引擎

 

5. 加密Cookie Session

SESSION_ENGINE = 'django.contrib.sessions.backends.signed_cookies'   # 引擎

 

其他公用設置項:

SESSION_COOKIE_NAME "sessionid"                       # Sessioncookie保存在瀏覽器上時的key,即:sessionid=隨機字符串(默認)

SESSION_COOKIE_PATH "/"                               # Sessioncookie保存的路徑(默認)

SESSION_COOKIE_DOMAIN = None                             # Sessioncookie保存的域名(默認)

SESSION_COOKIE_SECURE = False                            # 是否Https傳輸cookie(默認)

SESSION_COOKIE_HTTPONLY = True                           # 是否Sessioncookie只支持http傳輸(默認)

SESSION_COOKIE_AGE = 1209600                             # Sessioncookie失效日期(2周)(默認)

SESSION_EXPIRE_AT_BROWSER_CLOSE = False                  # 是否關閉瀏覽器使得Session過期(默認) 

SESSION_SAVE_EVERY_REQUEST = False                       # 是否每次請求都保存Session,默認修改之后才保存(默認)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM