論session 原理

session

    session是什麼?

        是保存在服務器端的鍵值對

    session必須依賴於Cookie

    

  django中session做的事兒:

   

存session:

在服務端生成隨機字符串
生成一個和上面隨機字符串對應的大字典,用來保存用戶的數據
隨機字符串當成cookie返回給瀏覽器


取session:

從請求攜帶的Cookie裏面找到隨機字符串
拿到隨機字符串取session中找到對應的大字典
從打字段中根據key去取值


session 相較於Cookie的優勢:

比Cookie能存的數據多
安全性好,數據都保存在服務器端


 

Session的由來

Cookie雖然在一定程度上解決了“保持狀態”的需求,但是由於Cookie本身最大支持4096字節,以及Cookie本身保存在客戶端,可能被攔截或竊取,因此就需要有一種新的東西,它能支持更多的字節,並且他保存在服務器,有較高的安全性。這就是Session。

問題來了,基於HTTP協議的無狀態特徵,服務器根本就不知道訪問者是“誰”。那麼上述的Cookie就起到橋接的作用。

我們可以給每個客戶端的Cookie分配一個唯一的id,這樣用戶在訪問時,通過Cookie,服務器就知道來的人是“誰”。然後我們再根據不同的Cookie的id,在服務器上保存一段時間的私密資料,如“賬號密碼”等等。

總結而言:Cookie彌補了HTTP無狀態的不足,讓服務器知道來的人是“誰”;但是Cookie以文本的形式保存在本地,自身安全性較差;所以我們就通過Cookie識別不同的用戶,對應的在Session裏保存私密的信息以及超過4096字節的文本。

另外,上述所說的Cookie和Session其實是共通性的東西,不限於語言和框架。

Django中Session相關方法

# 獲取、設置、刪除Session中數據
request.session['k1']
request.session.get('k1',None)
request.session['k1'] = 123request.session.setdefault('k1',123) # 存在則不設置
del request.session['k1']


# 所有 鍵、值、鍵值對
request.session.keys()
request.session.values()
request.session.items()
request.session.iterkeys()
request.session.itervalues()
request.session.iteritems()

# 會話session的key
request.session.session_key

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

# 檢查會話session的key在數據庫中是否存在
request.session.exists("session_key")

# 刪除當前會話的所有Session數據
request.session.delete()
  
# 刪除當前的會話數據並刪除會話的Cookie。
request.session.flush() 
    這用於確保前面的會話數據不可以再次被用戶的瀏覽器訪問
    例如,django.contrib.auth.logout() 函數中就會調用它。

# 設置會話Session和Cookie的超時時間
request.session.set_expiry(value)    * 如果value是個整數,session會在些秒數後失效。    * 如果value是個datatime或timedelta,session就會在這個時間後失效。    * 如果value是0,用戶關閉瀏覽器session就會失效。    * 如果value是None,session會依賴全局session失效策略。


Session流程解析

image.png

Session版登陸驗證

from functools import wraps


def check_login(func):
    @wraps(func)
    def inner(request,*args,**kwargs):
        next_url = request.get_full_path()
        if request.session.get("user"):
            return func(request,*args,**kwargs)
        else:
            return redirect("/login/?next={}".format(next_url))
    return  inner
    
def login(request):
    if request.method == "POST":
        user = request.POST.get("user")
        pwd = request.POST.get("pwd")
        
        if user == 'john' and pwd == "john123":
            #設置session
            request.session["user"] = user
            #獲取跳到登錄頁面之前的URL
            next_url = request.GET.get("next")
            #如果有,就跳轉回登錄之前的URL
            if next_url:
                return redirect(next_url)
            #否則默認跳轉到index頁面
            else:
                return redirect("/index/")
    return render(request,"login.html")
    
@check_login
def logout(request):
    #刪除所有當前請求相關的session
    requestsession.delete()
    return redirect("/login/")
    
@check_login
def index(request):
    current_user = request.session.get("user",None)
    return render(request,"index.html",{"user":current_user})

  

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"                       # Session的cookie保存在瀏覽器上時的key,即:sessionid=隨機字符串(默認)
SESSION_COOKIE_PATH = "/"                               # Session的cookie保存的路徑(默認)
SESSION_COOKIE_DOMAIN = None                             # Session的cookie保存的域名(默認)
SESSION_COOKIE_SECURE = False                            # 是否Https傳輸cookie(默認)
SESSION_COOKIE_HTTPONLY = True                           # 是否Session的cookie只支持http傳輸(默認)
SESSION_COOKIE_AGE = 1209600                             # Session的cookie失效日期(2周)(默認)
SESSION_EXPIRE_AT_BROWSER_CLOSE = False                  # 是否關閉瀏覽器使得Session過期(默認)
SESSION_SAVE_EVERY_REQUEST = False                       # 是否每次請求都保存Session,默認修改之後才保存(默認)

 


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章