Flask中Cookie和Session理解與作用介紹
前序
1、cookie介紹
Cookie是一段不超過4KB的小型文本數(shù)據(jù),保存在客戶端瀏覽器中,由一個(gè)名稱(Name)、一個(gè)值(Value)和其它幾個(gè)用于控制Cookie有效期、安全性、使用范圍的可選屬性組成。其中 :
(1) Name/Value:設(shè)置Cookie的名稱及相對(duì)應(yīng)的值,對(duì)于認(rèn)證Cookie,Value值包括Web服務(wù)器所提供的訪問令牌。
(2) Expires屬性:設(shè)置Cookie的生存期。有兩種存儲(chǔ)類型的Cookie:會(huì)話性與持久性。Expires屬性缺省時(shí),為會(huì)話性Cookie,僅保存在客戶端內(nèi)存中,并在用戶關(guān)閉瀏覽器時(shí)失效;持久性Cookie會(huì)保存在用戶的硬盤中,直至生存期到或用戶直接在網(wǎng)頁(yè)中單擊“注銷”等按鈕結(jié)束會(huì)話時(shí)才會(huì)失效 。
(3) Path屬性:定義了Web站點(diǎn)上可以訪問該Cookie的目錄 。
(4) Domain屬性:指定了可以訪問該 Cookie 的 Web 站點(diǎn)或域。
2、session介紹
Session:與cookie功能效果相同。Session與Cookie的區(qū)別在于Session是記錄在服務(wù)端的,而Cookie是記錄在客戶端的。
當(dāng)訪問服務(wù)器否個(gè)網(wǎng)頁(yè)的時(shí)候,會(huì)在服務(wù)器端的內(nèi)存里開辟一塊內(nèi)存,這塊內(nèi)存就叫做session,而這個(gè)內(nèi)存是跟瀏覽器關(guān)聯(lián)在一起的。這個(gè)瀏覽器指的是瀏覽器窗口,或者是瀏覽器的子窗口,意思就是,只允許當(dāng)前這個(gè)session對(duì)應(yīng)的瀏覽器訪問,就算是在同一個(gè)機(jī)器上新啟的瀏覽器也是無法訪問的。而另外一個(gè)瀏覽器也需要記錄session的話,就會(huì)再啟一個(gè)屬于自己的session。
一、cookie學(xué)習(xí)
1、設(shè)置cookie
- 在服務(wù)器設(shè)置cookie需要導(dǎo)入make_response包
- response=make_response(‘hello world’) 括號(hào)這里傳入的值是在客戶端響應(yīng)的內(nèi)容
- response.set_cookie(‘username’,‘mashibing’,max_age=3600) 第一個(gè)值是cookie名稱,第二個(gè)值cookie內(nèi)容,第三個(gè)值設(shè)置cookie的有效時(shí)間
- 這個(gè)有效時(shí)間在服務(wù)器沒有關(guān)閉的狀態(tài)下,有效時(shí)間內(nèi),即使你關(guān)閉了客戶端(瀏覽器),再次打開客戶端(瀏覽器)仍能訪問到。
from flask import *
app=Flask(__name__)
#設(shè)置cookie以及有效性期
@app.route('/cookie')
def set_cookiei():
response=make_response('hello world')
response.set_cookie('username','mashibing',max_age=3600)
return response
#讀取
@app.route('/get_cookie')
def get_cookie():
resp=request.cookies.get('username')
return resp
if __name__ == '__main__':
app.run()2、客戶端(瀏覽器)

二、session學(xué)習(xí)
1、設(shè)置SECRET_KEY
- 這里SECRET_KEY的值是可以隨機(jī)設(shè)置,可以使用os.urandom(24) 隨機(jī)生成24位字符
- 此值 [ SECRET_KEY 設(shè)置]是保護(hù)簽名數(shù)據(jù)的關(guān)鍵 - 保持此安全至關(guān)重要,否則攻擊者可以使用它來生成自己的簽名值。
- 設(shè)置SECRET_KEY 配合加密算法生成sessionID
- PERMANENT_SESSION_LIFETIME=timedelta(minutes=30) 設(shè)置該sessionID在服務(wù)器存儲(chǔ)的時(shí)間,在有效時(shí)間內(nèi)客戶端(瀏覽器)關(guān)掉后再次重新訪問時(shí),會(huì)對(duì)其session ID進(jìn)行校驗(yàn),若是之前保存在服務(wù)器的session ID對(duì)應(yīng),則可以拿到之前session值。
class Df(object):
SECRET_KEY=os.urandom(24)
PERMANENT_SESSION_LIFETIME=timedelta(minutes=30)2、設(shè)置session
- 這里設(shè)置session值在客戶端是看不到的,相對(duì)安全,除非服務(wù)器崩了。
- 設(shè)置的session會(huì)保存在服務(wù)器。
- session.permanent=True #這行代碼也要寫不然前面定義的時(shí)間失效。
- 設(shè)置session是以鍵值對(duì)的形式。
@app.route('/test1')
def test1():
session.permanent=True #這行代碼也要寫不然前面定義的時(shí)間失效
#設(shè)置session
session['un']='ywx'
session['pwd']='123456'
return 'hello ywx'3、獲取session值
通過session.get() 獲取定義的值
#讀取session
@app.route('/test2')
def test2():
un=session.get('un')
pwd=session.get('pwd')
print(un,pwd)
return '獲取session的值'4、整體代碼展示
from flask import *
import os
from datetime import timedelta
app=Flask(__name__)
#設(shè)置SECRET_KEY
class Df(object):
SECRET_KEY=os.urandom(24)
PERMANENT_SESSION_LIFETIME=timedelta(minutes=30)
#導(dǎo)進(jìn)來參數(shù)
app.config.from_object(Df)
@app.route('/test1')
def test1():
session.permanent=True #這行代碼也要寫不然前面定義的時(shí)間失效
#設(shè)置session
session['un']='ywx'
session['pwd']='123456'
return 'hello ywx'
#讀取session
@app.route('/test2')
def test2():
un=session.get('un')
pwd=session.get('pwd')
print(un,pwd)
return '獲取session的值'
if __name__ == '__main__':
app.run()5、客戶端(瀏覽器)展示

到此這篇關(guān)于Flask中Cookie和Session理解與作用介紹的文章就介紹到這了,更多相關(guān)Flask Cookie Session內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Keras之fit_generator與train_on_batch用法
這篇文章主要介紹了Keras之fit_generator與train_on_batch用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-06-06
Python2.x利用commands模塊執(zhí)行Linux shell命令
這篇文章主要介紹了Python2.x利用commands模塊執(zhí)行Linux shell命令 的相關(guān)資料,需要的朋友可以參考下2016-03-03
Python實(shí)現(xiàn)帶參數(shù)的用戶驗(yàn)證功能裝飾器示例
這篇文章主要介紹了Python實(shí)現(xiàn)帶參數(shù)的用戶驗(yàn)證功能裝飾器,結(jié)合實(shí)例形式分析了Python用戶驗(yàn)證裝飾器具體定義及使用技巧,需要的朋友可以參考下2018-12-12

