1. 程式人生 > >Django視圖——狀態保持(SESSION)

Django視圖——狀態保持(SESSION)

視圖 django 狀態保持

-- 狀態保持

# http協議是
無狀態的;不記錄你之前幹過什麽;
# 實現狀態保持的方式:在客戶端或服務器端存儲與會話有關的數據;
# 使用cookie,所有數據存儲在客戶端,註意不要存儲敏感信息
# 推薦使用sesison方式,所有數據存儲在服務器端,在客戶端cookie中存儲session_id
# 狀態保持的目
的是在一段時間內跟蹤請求者的狀態,可以實現跨頁面訪問當前請求者的數據

-- SESSION

-- 啟用(默認啟用)

# 項INSTALLED_APPS列表中添加:
# ‘django.contrib.sessions‘,
# 項MIDDLEWARE_CLASSES列表中添加:
# ‘django.contrib.sessions.middleware.SessionMiddleware‘,
# 禁用會話:刪除上面指定的兩個值,禁用會話將節省一些性能消耗;(代碼註釋)

-- 使用

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

-- 示例

-- views.py

# # 通過用戶登錄練習session
# def session1(request):
# # 通過get()獲取,就算沒有值也不會報錯,會彈出默認none;
# # 也可以自己傳入一個參數來改寫默認值;
# # 如果通過字典方式,就會報錯;
# uname = request.session.get(‘myname‘, ‘未登錄‘)
# context = {‘uname‘:uname}
# return render(request, ‘booktest/session1.html‘, context)
# def session2(request):
# return render(request, ‘booktest/session2.html‘)
# def session2_handle(request):
# # 保存對session頁面的表單中提交的內容,到數據庫中的session表;
# # 並重定向至session1頁面;
# uname = request.POST[‘uname‘]
# request.session[‘myname‘] = uname
# return redirect(‘/booktest/session1/‘)
# def session3(request):
# # 刪除session
# del request.session[‘myname‘]
# # 重定向至session1頁面;
# return redirect(‘/booktest/session1/‘)

-- 配置url

# url(r‘^session1/$‘, views.session1),
# url(r‘^session2/$‘, views.session2),
# url(r‘^session2_handle/$‘, views.session2_handle),
# url(r‘^session3/$‘, views.session3),

-- 創建session1.html

# <body>
#  你好:{{uname}}
#  <br>
#  <a href="/booktest/session2">登錄</a>
#  <br>
#  <a href="/booktest/session3">退出</a>
# </body>

-- 創建session2.html

# <body>
# <form method=‘post‘ actions="/booktest/session2_handle">
# <input type="text" name="uname">
# <input type="submit" name="登錄">
# </form>
# </body>

# -- 通過session存值

# -- 通過session取值

# -- 刪除session值


-- 會話過期時間

-- set_expiry(value):

-- 設置會話的超時時間

-- 如果沒有指定,則兩個星期後過期

# 如果value是一個整數,會話將在values秒沒有活動後過期
# 若果value是一個imedelta對象,會話將在當前時間加上這個指定的日期/時間過期
# 如果value為0,那麽用戶會話的Cookie將在用戶的瀏覽器關閉時過期
# 如果value為None,那麽會話永不過期
# def session2_handle(request):
# # 保存對session頁面的表單中提交的內容,到數據庫中的session表;
# # 並重定向至session1頁面;
# uname = request.POST[‘uname‘]
# request.session[‘myname‘] = uname
#     # request.session.set_expiry(10)
#     # request.session.set_expiry(timedelta(days=5))
#     # request.session.set_expiry(0)
#     # request.session.set_expiry(None)
# return redirect(‘/booktest/session1/‘)


-- 存儲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

# session依賴於cookie?

-- 安裝包

# 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:使用客戶端連接服務器
# keys *:查看所有的鍵
# get name:獲取指定鍵的值
# del name:刪除指定名稱的鍵


Django視圖——狀態保持(SESSION)