一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - Flask 入門系列 Cookie與session的介紹

Flask 入門系列 Cookie與session的介紹

2022-03-08 00:15tigeriaf Python

這篇文章主要給大家分享的是 Flask 入門系列 Cookie與session的介紹,下面文字圍繞 Cookie與session的相關(guān)資料展開詳情,需要的朋友可以參考一下,希望對大家有所幫助

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 通常被用來進行用戶會話管理(比如用戶的登錄狀態(tài)),保存用戶的一些信息。

2、在Flask中使用Cookie

Flask 中,如果想要在響應(yīng)中添加一個 cookie,可以使用 response 對象的set_cookie()方法。

set_ cookie()方法的參數(shù)如下:

  • keycookie 鍵名
  • valuecookie
  • max_agecookie 被保存的時間,單位:秒
  • expires:具體的過期時間
  • path:限制 cookie 可用的路徑,默認為整個域名
  • domaincookie 可用的域名
  • secure:設(shè)置為 True,只有通過 HTTPS 才可使用
  • httponly:設(shè)置為True,禁止客戶端 js 獲取 cookie

具體使用如下:

?
1
2
3
4
5
6
7
8
9
@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 屬性獲取。

?
1
2
3
4
5
6
7
8
9
10
11
@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 指用戶會話,會話可以用來保存當前請求的一些狀態(tài),以便于在請求之前共享信息。session是存儲在服務(wù)端的,通過唯一標識區(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)容進行加密。Flask 提供了 session 對象就是用來將 Cookie 數(shù)據(jù)加密存儲的。

3、在Flask中使用session

session 需要通過密鑰對數(shù)據(jù)進行簽名以加密數(shù)據(jù),因此,需要先設(shè)置一個密鑰app.secret_key,這里設(shè)置的密鑰只是一個簡單示例,在生產(chǎn)環(huán)境中,必須要隨機生成的密鑰,保證秘鑰的復(fù)雜度度和隨機性,才更安全。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
# 設(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)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://juejin.cn/post/7030627770677854245

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本高清在线精品一区二区三区 | 青青国产精品 | 久久一本综合 | 韩国三级在线观看 完整版 韩国三级视频网站 | 亚洲乱亚洲乱妇41p国产成人 | 色啪久久婷婷综合激情 | 国产欧美日韩一区二区三区在线 | 天天爱综合网 | 精品国产一级毛片大全 | 黄色大片网| 学校捏奶揉下面污文h | 动漫美女强行被吸乳做羞羞事 | 日本一本草久p | 国产精品露脸国语对白河北 | 精品国产福利在线 | 人妖女天堂视频在线96 | 男人把大ji巴放进女人小说 | 国产精品视频免费看 | 肉性天堂 | 五月天在线视频观看 | a级片在线播放 | 国产午夜精品久久理论片小说 | 亚洲波多野结衣日韩在线 | 日韩播放| 精品人人做人人爽久久久 | 国产精品久久国产精品99 | 星空传媒在线视频 | 国产永久一区二区三区 | 99福利网| 九九九精品视频 | 日韩大片在线播放 | 精品夜夜澡人妻无码AV蜜桃 | 午夜福利理论片在线播放 | 欧美日韩一区二区综合在线视频 | 国产麻豆在线观看网站 | 亚洲一区二区福利视频 | 久久99re热在线观看视频 | 99热这里只有精品国产在热久久 | 99国产牛牛视频在线网站 | 韩国情事伦理片观看地址 | 女子张腿让男人桶免费 |