成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

論session原理-創(chuàng)新互聯(lián)

session

創(chuàng)新互聯(lián)從2013年成立,先為銅官等服務(wù)建站,銅官等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為銅官企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。

    session是什么?


        是保存在服務(wù)器端的鍵值對(duì)


    session必須依賴于Cookie



 django中session做的事兒:



存session:

在服務(wù)端生成隨機(jī)字符串
生成一個(gè)和上面隨機(jī)字符串對(duì)應(yīng)的大字典,用來(lái)保存用戶的數(shù)據(jù)
隨機(jī)字符串當(dāng)成cookie返回給瀏覽器

取session:

從請(qǐng)求攜帶的Cookie里面找到隨機(jī)字符串
拿到隨機(jī)字符串取session中找到對(duì)應(yīng)的大字典
從打字段中根據(jù)key去取值

session 相較于Cookie的優(yōu)勢(shì):

比Cookie能存的數(shù)據(jù)多
安全性好,數(shù)據(jù)都保存在服務(wù)器端

Session的由來(lái)

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

問(wèn)題來(lái)了,基于HTTP協(xié)議的無(wú)狀態(tài)特征,服務(wù)器根本就不知道訪問(wèn)者是“誰(shuí)”。那么上述的Cookie就起到橋接的作用。

我們可以給每個(gè)客戶端的Cookie分配一個(gè)唯一的id,這樣用戶在訪問(wèn)時(shí),通過(guò)Cookie,服務(wù)器就知道來(lái)的人是“誰(shuí)”。然后我們?cè)俑鶕?jù)不同的Cookie的id,在服務(wù)器上保存一段時(shí)間的私密資料,如“賬號(hào)密碼”等等。

總結(jié)而言:Cookie彌補(bǔ)了HTTP無(wú)狀態(tài)的不足,讓服務(wù)器知道來(lái)的人是“誰(shuí)”;但是Cookie以文本的形式保存在本地,自身安全性較差;所以我們就通過(guò)Cookie識(shí)別不同的用戶,對(duì)應(yīng)的在Session里保存私密的信息以及超過(guò)4096字節(jié)的文本。

另外,上述所說(shuō)的Cookie和Session其實(shí)是共通性的東西,不限于語(yǔ)言和框架。

Django中Session相關(guān)方法

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


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

# 會(huì)話session的key
request.session.session_key

# 將所有Session失效日期小于當(dāng)前日期的數(shù)據(jù)刪除
request.session.clear_expired()

# 檢查會(huì)話session的key在數(shù)據(jù)庫(kù)中是否存在
request.session.exists("session_key")

# 刪除當(dāng)前會(huì)話的所有Session數(shù)據(jù)
request.session.delete()
  
# 刪除當(dāng)前的會(huì)話數(shù)據(jù)并刪除會(huì)話的Cookie。
request.session.flush() 
    這用于確保前面的會(huì)話數(shù)據(jù)不可以再次被用戶的瀏覽器訪問(wèn)
    例如,django.contrib.auth.logout() 函數(shù)中就會(huì)調(diào)用它。

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

Session流程解析

論session 原理

Session版登陸驗(yàn)證

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":
            #設(shè)置session
            request.session["user"] = user
            #獲取跳到登錄頁(yè)面之前的URL
            next_url = request.GET.get("next")
            #如果有,就跳轉(zhuǎn)回登錄之前的URL
            if next_url:
                return redirect(next_url)
            #否則默認(rèn)跳轉(zhuǎn)到index頁(yè)面
            else:
                return redirect("/index/")
    return render(request,"login.html")
    
@check_login
def logout(request):
    #刪除所有當(dāng)前請(qǐng)求相關(guān)的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中默認(rèn)支持Session,其內(nèi)部提供了5種類型的Session供開(kāi)發(fā)者使用。

1. 數(shù)據(jù)庫(kù)Session
SESSION_ENGINE = 'django.contrib.sessions.backends.db'   # 引擎(默認(rèn))2. 緩存Session
SESSION_ENGINE = 'django.contrib.sessions.backends.cache'  # 引擎
SESSION_CACHE_ALIAS = 'default'                            # 使用的緩存別名(默認(rèn)內(nèi)存緩存,也可以是memcache),此處別名依賴緩存的設(shè)置3. 文件Session
SESSION_ENGINE = 'django.contrib.sessions.backends.file'    # 引擎
SESSION_FILE_PATH = None                                    # 緩存文件路徑,如果為None,則使用tempfile模塊獲取一個(gè)臨時(shí)地址tempfile.gettempdir() 

4. 緩存+數(shù)據(jù)庫(kù)
SESSION_ENGINE = 'django.contrib.sessions.backends.cached_db'        # 引擎5. 加密Cookie Session
SESSION_ENGINE = 'django.contrib.sessions.backends.signed_cookies'   # 引擎

其他公用設(shè)置項(xiàng):
SESSION_COOKIE_NAME = "sessionid"                       # Session的cookie保存在瀏覽器上時(shí)的key,即:sessionid=隨機(jī)字符串(默認(rèn))
SESSION_COOKIE_PATH = "/"                               # Session的cookie保存的路徑(默認(rèn))
SESSION_COOKIE_DOMAIN = None                             # Session的cookie保存的域名(默認(rèn))
SESSION_COOKIE_SECURE = False                            # 是否Https傳輸cookie(默認(rèn))
SESSION_COOKIE_HTTPONLY = True                           # 是否Session的cookie只支持http傳輸(默認(rèn))
SESSION_COOKIE_AGE = 1209600                             # Session的cookie失效日期(2周)(默認(rèn))
SESSION_EXPIRE_AT_BROWSER_CLOSE = False                  # 是否關(guān)閉瀏覽器使得Session過(guò)期(默認(rèn))
SESSION_SAVE_EVERY_REQUEST = False                       # 是否每次請(qǐng)求都保存Session,默認(rèn)修改之后才保存(默認(rèn))

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

新聞名稱:論session原理-創(chuàng)新互聯(lián)
文章URL:http://jinyejixie.com/article6/hgiig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、電子商務(wù)、關(guān)鍵詞優(yōu)化、ChatGPT、網(wǎng)站導(dǎo)航、App開(kāi)發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
永修县| 获嘉县| 驻马店市| 古蔺县| 哈尔滨市| 屏山县| 乌鲁木齐市| 广汉市| 涟源市| 广汉市| 商城县| 平邑县| 辽中县| 崇文区| 宁南县| 绍兴市| 礼泉县| 沈阳市| 浦北县| 中阳县| 萨嘎县| 怀仁县| 南雄市| 久治县| 西丰县| 临潭县| 栖霞市| 威信县| 秦安县| 桃园市| 中西区| 新竹县| 长海县| 蚌埠市| 松阳县| 榆树市| 灵石县| 治多县| 蓝田县| 湘乡市| 宁武县|