Flask 入門系列 Cookie與session的介紹

一、Cookie的使用
1、什么是Cookie
我們都知道,HTTP 協(xié)議是無狀態(tài)的,也就是說,在一次請求響應(yīng)結(jié)束后,服務(wù)端不會保留任何對方狀態(tài)的信息,對于某些需要保留的信息,可以通過 Cookie 技術(shù)來完成,通過在請求和響應(yīng)報文中添加 Cookie 數(shù)據(jù)來保存客戶端的狀態(tài)信息。
Web 服務(wù)器為了存儲某些數(shù)據(jù)(比如用戶信息) 而保存在瀏覽器上的小型文本數(shù)據(jù),瀏覽器會在一定時間內(nèi)保存它,在下次向該服務(wù)器發(fā)送請求時附帶這些數(shù)據(jù),Cookie 通常被用來進(jìn)行用戶會話管理(比如用戶的登錄狀態(tài)),保存用戶的一些信息。
2、在Flask中使用Cookie
在 Flask 中,如果想要在響應(yīng)中添加一個 cookie,可以使用 response 對象的set_cookie()方法。
set_ cookie()方法的參數(shù)如下:
key:cookie鍵名value:cookie值max_age:cookie被保存的時間,單位:秒expires:具體的過期時間- path:限制
cookie可用的路徑,默認(rèn)為整個域名 domain:cookie可用的域名secure:設(shè)置為True,只有通過 HTTPS 才可使用httponly:設(shè)置為True,禁止客戶端 js 獲取cookie
具體使用如下:
@app.route('user/<name>')
def user(name):
response = make_response('hello {}'.format(name), 200)
response.set_cookie("name", name)
return response
在 Flask 中,Cookie 可以通過 request 請求對象 cookies 屬性獲取。
@app.route('/hello')
def hello():
user = request.args.get('name')
if not user:
user = request.cookies.get("name", 'default')
return 'Hello {}!'.format(user)
二、session的使用
1、什么是session
session 指用戶會話,會話可以用來保存當(dāng)前請求的一些狀態(tài),以便于在請求之前共享信息。session是存儲在服務(wù)端的,通過唯一標(biāo)識區(qū)分用戶 session,即 session id,一般情況下,session id 是存在 Cookie 中的,服務(wù)端可以獲取 Cookie 中的 session id 來獲取用戶 session。
2、Flask中的session對象
我們了解了 Cookie 最重要的功能是用來保存客戶端用戶的狀態(tài)信息。但是存在這樣一個問題,Cookie 是保存在客戶端的,在瀏覽器中可以輕易的添加和修改 Cookie,而且如果把用戶的狀態(tài)信息以明文的方式存儲在 Cookie 里的話,那么就可以通過偽造 Cookie 信息來偽造別人的用戶信息,從而獲取一些權(quán)限。為了避免這個問題,我們要對敏感的 Cookie 內(nèi)容進(jìn)行加密。Flask 提供了 session 對象就是用來將 Cookie 數(shù)據(jù)加密存儲的。
3、在Flask中使用session
session 需要通過密鑰對數(shù)據(jù)進(jìn)行簽名以加密數(shù)據(jù),因此,需要先設(shè)置一個密鑰app.secret_key,這里設(shè)置的密鑰只是一個簡單示例,在生產(chǎn)環(huán)境中,必須要隨機(jī)生成的密鑰,保證秘鑰的復(fù)雜度度和隨機(jī)性,才更安全。
# 設(shè)置密鑰
app.secret_key = 'qwertyuiop'
@app.route('/user', methods=['POST', 'GET'])
def user():
if request.method == 'POST':
user = request.form['user_name']
session['user_name'] = request.form['user_name']
return 'Hello {}!'.format(user)
else:
if 'user_name' in session:
return 'Hello {}!'.format(session["user_name"])
session 對象的使用就跟字典一樣,如上,用戶使用POST請求登錄后,在 session 中保存用戶名,下次再使用GET請求時,不傳遞任何信息,也可以在 session 中獲取該用戶的信息。
想要清除 session 指定信息的話,例如用戶名,可以使用 session.pop("user_name", None),清除全部的話可以使用session.clear()。
到此這篇關(guān)于 Flask 入門系列 Cookie與session的介紹的文章就介紹到這了,更多相關(guān) Flask? Cookie與session內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python pyttsx3庫實(shí)現(xiàn)文本轉(zhuǎn)語音功能的示例
pyttsx3是一個功能強(qiáng)大且易于使用的文本轉(zhuǎn)語音庫,適合需要離線語音合成的場景,本文就來介紹一下Python pyttsx3庫實(shí)現(xiàn)文本轉(zhuǎn)語音功能的示例,感興趣的可以了解一下2025-04-04
使用Pyinstaller的最新踩坑實(shí)戰(zhàn)記錄
這篇文章主要給大家介紹了最近在使用Pyinstaller的踩坑實(shí)戰(zhàn)記錄,主要介紹了PYTHON2X.DLL缺失和WINDOWS2003 32BIT提示程序無效這兩個問題的解決方法,文中給出了詳細(xì)的解決方法,需要的朋友們下面來一起看看吧。2017-11-11
python實(shí)現(xiàn)壓縮包圖片預(yù)覽與收藏功能
在日常處理圖片資料時,我們經(jīng)常會遇到大量打包在壓縮文件中的照片,逐個解壓再查看不僅麻煩,而且浪費(fèi)時間,下面我們來看看如何使用Python實(shí)現(xiàn)壓縮包圖片預(yù)覽與收藏功能吧2025-09-09
Python讀取JSON數(shù)據(jù)操作實(shí)例解析
這篇文章主要介紹了Python讀取JSON數(shù)據(jù)操作實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-05-05
Python輸出由1,2,3,4組成的互不相同且無重復(fù)的三位數(shù)
這篇文章主要介紹了Python輸出由1,2,3,4組成的互不相同且無重復(fù)的三位數(shù),分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下2018-02-02
使用BeautifulSoup爬蟲程序獲取百度搜索結(jié)果的標(biāo)題和url示例
這篇文章主要介紹了使用BeautifulSoup編寫了一段爬蟲程序獲取百度搜索結(jié)果的標(biāo)題和url的示例,大家參考使用吧2014-01-01
Python3中簡單的文件操作及兩個簡單小實(shí)例分享
文件操作是我們?nèi)粘T谑褂胮ython的時候經(jīng)常會用到的,下面這篇文章主要給大家介紹了關(guān)于Python3中簡單的文件操作及兩個簡單小實(shí)例的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。2017-06-06

