Django框架第十講-session

狀態保持

  • http的協議是無狀態的:每次的請求都是一次新的請求,不會記得之前通信狀態
  • 客戶端與服務器端的一次通信,就是一次會話
  • 實現狀態保持的方式:在客戶端或服務器端存儲與會話有關的數據
  • 存儲方式包括cookie、session,會話一般指session對象
  • 使用cookie,所有數據存儲在客戶端,注意不要存儲敏感信息
  • 推薦使用sesison方式,所有數據存儲在服務器端,在客戶端cookie中存儲session_id
  • 狀態保持的目的是在一段時間內跟蹤請求者的狀態,可以實現跨頁面訪問當前請求者的數據
  • 注意:不同的請求者之間不會共享這個數據,與請求者一一對應

啟用session

  • 使用django-admin startproject創建的項目默認啟用
  • 在settings.py文件中
Django框架第十講-session

  • 禁用會話:刪除上面指定的兩個值,禁用會話將節省一些性能消耗

使用session

  • 啟用會話後,每個HttpRequest對象將具有一個session屬性,它是一個類字典對象
  • get(key, default=None):根據鍵獲取會話的值
  • clear():清除所有會話
  • flush():刪除當前的會話數據並刪除會話的Cookie
  • del request.session['member_id']:刪除會話

用戶登錄示例

  • 操作效果如下圖:
Django框架第十講-session

  • 在views.py文件中創建視圖
Django框架第十講-session

  • 配置url
Django框架第十講-session

  • 創建模板index.html
Django框架第十講-session

  • 創建模板login.html
Django框架第十講-session

會話過期時間

  • set_expiry(value):設置會話的超時時間
  • 如果沒有指定,則兩個星期後過期
  • 如果value是一個整數,會話將在values秒沒有活動後過期
  • 若果value是一個imedelta對象,會話將在當前時間加上這個指定的日期/時間過期
  • 如果value為0,那麼用戶會話的Cookie將在用戶的瀏覽器關閉時過期
  • 如果value為None,那麼會話永不過期
  • 修改視圖中login_handle函數,查看效果
Django框架第十講-session

Django框架第十講-session

存儲session

  • 使用存儲會話的方式,可以使用settings.py的SESSION_ENGINE項指定
  • 基於數據庫的會話:這是django默認的會話存儲方式,需要添加django.contrib.sessions到的INSTALLED_APPS設置中,運行manage.py migrate在數據庫中安裝會話表,可顯示指定為

SESSION_ENGINE='django.contrib.sessions.backends.db'

  • 基於緩存的會話:只存在本地內在中,如果丟失則不能找回,比數據庫的方式讀寫更快

SESSION_ENGINE='django.contrib.sessions.backends.cache'

  • 可以將緩存和數據庫同時使用:優先從本地緩存中獲取,如果沒有則從數據庫中獲取

SESSION_ENGINE='django.contrib.sessions.backends.cached_db'

使用Redis緩存session

  • 會話還支持文件、純cookie、Memcached、Redis等方式存儲,下面演示使用redis存儲
  • 安裝包

pip install django-redis-sessions

  • 修改settings中的配置,增加如下項
Django框架第十講-session

  • 管理redis的命令

點擊關注發私信(基礎視頻),即可獲取下載鏈接:

Django框架第十講-session


分享到:


相關文章: