簡單的介紹
- http協(xié)議是無狀態(tài)的:每次請求都是一次新的請求,不會記得之前通信的狀
態(tài) - 客戶端與服務(wù)器端的一次通信,就是一次會話
- 實現(xiàn)狀態(tài)保持的方式:在客戶端或服務(wù)器端存儲與會話有關(guān)的數(shù)據(jù)
- 存儲方式包括cookie、session,會話一般指session對象
- 使用cookie,所有數(shù)據(jù)存儲在客戶端,注意不要存儲敏感信息
- 推薦使用sesison方式暖哨,所有數(shù)據(jù)存儲在服務(wù)器端,在客戶端cookie中存儲
session_id - 狀態(tài)保持的目的是在一段時間內(nèi)跟蹤請求者的狀態(tài)凰狞,可以實現(xiàn)跨頁面訪問當(dāng)
前請求者的數(shù)據(jù) - 注意:不同的請求者之間不會共享這個數(shù)據(jù)篇裁,與請求者一一對應(yīng)
啟用session
使用django-admin startproject創(chuàng)建的項目默認(rèn)啟用
-
在settings.py文件中
INSTALLED_APPS列表中添加:'django.contrib.sessions'
MIDDLEWARE_CLASSES列表中添加:
'django.contrib.sessions.middleware.SessionMiddleware',
使用session
- 啟用會話后,每個HttpRequest對象
將具有一個session屬性赡若,它是一個
類字典對象 - get(key, default=None):根據(jù)鍵獲取會話的值
- clear():清除所有會話
- flush():刪除當(dāng)前的會話數(shù)據(jù)并刪除
會話的Cookie - del request.session[‘member_id’]:
刪除會話
會話過期時間
- set_expiry(value):設(shè)置會話的超時時間
- 如果沒有指定达布,則兩個星期后過期
- 如果value是一個整數(shù),會話將在values秒沒有活動后過期
- 若果value是一個timedelta對象會將在當(dāng)前時間加上這個指定的日期/時間過
期 - 如果value為0逾冬,那么用戶會話的Cookie將在用戶的瀏覽器關(guān)閉時過期
- 如果value為None黍聂,那么會話永不過期修改視圖中l(wèi)ogin_handle函數(shù),查看
效果
存儲session
使用存儲會話的方式身腻,可以使用settings.py的SESSION_ENGINE項指定
-
基于數(shù)據(jù)庫的會話:這是django默認(rèn)的會話存儲方式产还,需要添加django.contrib.sessions到的INSTALLED_APPS設(shè)置中,運(yùn)行manage.py migrate在數(shù)據(jù)庫中安裝會話表嘀趟,可顯示指定為
SESSION_ENGINE='django.contrib.sessions.backends.db'
-
基于緩存的會話:只存在本地內(nèi)在中脐区,如果丟失則不能找回,比數(shù)據(jù)庫的方式讀寫更快
SESSION_ENGINE='django.contrib.sessions.backends.cache'
-
可以將緩存和數(shù)據(jù)庫同時使用:優(yōu)先從本地緩存中獲取她按,如果沒有則從數(shù)據(jù)庫中獲取
SESSION_ENGINE='django.c ontrib.sessions.backends.cached_db'使用Redis緩存session
-
會話還支持文件牛隅、純cookie、Memcached酌泰、Redis等方式存儲媒佣,下面演示使用redis存儲
pip install django-redis-sessions
-
修改settings中的配置,增加如下項
SESSION_ENGINE = 'redis_sessions.session' SESSION_REDIS_HOST = 'localhost' SESSION_REDIS_PORT = 6379 SESSION_REDIS_DB = 0 SESSION_REDIS_PASSWORD = '' SESSION_REDIS_PREFIX = 'session'
-
管理redis的命令
啟動:sudo redis-server /etc/redis/redis.conf 停止:sudo redis-server stop 重啟:sudo redis-server restart redis-cli:使用客戶端連接服務(wù)器 keys *:查看所有的鍵 get name:獲取指定鍵的值 del name:刪除指定名稱的鍵