濮阳杆衣贸易有限公司

主頁 > 知識庫 > flask框架中的cookie和session使用

flask框架中的cookie和session使用

熱門標簽:如何申請400電話代理 江門智能電話機器人 天津塘沽區(qū)地圖標注 滴滴地圖標注公司 智能電話機器人調(diào)研 400電話在線如何申請 甘肅高頻外呼系統(tǒng) 杭州房產(chǎn)地圖標注 地圖標注可以遠程操作嗎

文章介紹了flask框架中的cookie和session。Session是在服務(wù)器端保存的一個數(shù)據(jù)結(jié)構(gòu),用來跟蹤用戶的狀態(tài),這個數(shù)據(jù)可以保存在集群、數(shù)據(jù)庫、文件中。Cookie是客戶端保存用戶信息的一種機制,用來記錄用戶的一些信息,也是實現(xiàn)Session的一種方式。

WEB -> cookie session

由于HTTP協(xié)議是無狀態(tài)的協(xié)議,所以服務(wù)端需要記錄用戶的狀態(tài)時,就需要用某種機制來識具體的用戶,這個機制就是Session.典型的場景比如購物車,當(dāng)你點擊下單按鈕時,由于HTTP協(xié)議無狀態(tài),所以并不知道是哪個用戶操作的,所以服務(wù)端要為特定的用戶創(chuàng)建了特定的Session,用用于標識這個用戶,并且跟蹤用戶,這樣才知道購物車里面有幾本書。這個Session是保存在服務(wù)端的,有一個唯一標識。

服務(wù)端如何識別特定的客戶?這個時候Cookie就登場了。每次HTTP請求的時候,客戶端都會發(fā)送相應(yīng)的Cookie信息到服務(wù)端。實際上大多數(shù)的應(yīng)用都是用 Cookie 來實現(xiàn)Session跟蹤的,第一次創(chuàng)建Session的時候,服務(wù)端會在HTTP協(xié)議中告訴客戶端,需要在 Cookie 里面記錄一個Session ID,以后每次請求把這個會話ID發(fā)送到服務(wù)器,我就知道你是誰了。

Cookie其實還可以用在一些方便用戶的場景下,設(shè)想你某次登陸過一個網(wǎng)站,下次登錄的時候不想再次輸入賬號了,怎么辦?這個信息可以寫到Cookie里面,訪問網(wǎng)站的時候,網(wǎng)站頁面的腳本可以讀取這個信息,就自動幫你把用戶名給填了,能夠方便一下用戶。這也是Cookie名稱的由來,給用戶的一點甜頭。

flask中的session和cookie

   flask中的session機制是將敏感數(shù)據(jù)加密后放入session,然后將session存入cookie,下次請求時,直接從瀏覽器發(fā)過來的cookie中獲取session,再從中獲取數(shù)據(jù)進行解密

   這樣操作更節(jié)省服務(wù)開銷,因為數(shù)據(jù)均存儲到客戶端

   大家可能會擔(dān)心這種做法的安全性,因為數(shù)據(jù)全部存儲在本地瀏覽器,很容易被盜取,但是安全性總是相對的,而且flask里面對session也有自己的特殊加密算法,所以也不用太過于在意安全方面的問題

Session操作

1.使用sessiom需要先導(dǎo)入session

from flask import session

2.SECRET_KEY

    一定記得要設(shè)置SECRET_KEY,用于加密數(shù)據(jù),并且如果每次啟動服務(wù)器你的秘鑰都在變化的話就不能再用之前的SECRET_KEY進行解密了,我們此處就可以將它設(shè)置成固定值,對于配置文件里面變量的設(shè)置,前文講過,如果數(shù)據(jù)量比較多就單獨在config.py里面集成,但是如果只是很微量的幾條設(shè)置,那么就可以在主文件里簡單進行指令設(shè)置即可,類似這里的:

#生成隨機的24位字符串
app.config['SECRET_KEY'] = os.urandom(24)

3.session值添加

因為session和cookie都是鍵值對形式的字典,所以直接用字典方法添加就可以了

session['username'] = 'user1'

4.session值刪除

#1.單條刪除
session.pop('username')
del session['username']
#2. 全部清除
session.clear()

5.session值獲取

session.get('username')
session['username']

6.設(shè)置過期時間(如果不設(shè)置,默認瀏覽器退出即自動結(jié)束)

#在config.py中配置session參數(shù)PERMANENT_SESSION_LIFETIME,這個值的數(shù)據(jù)類型是datetime.timedelay類型
app.config['PERMANENT_SESSION_LIFETIME'] = timedelta(days=7) 
session.permanent = True #默認為31天

在Flask中對cookie的處理

1. 設(shè)置cookie:

設(shè)置cookie,默認有效期是臨時cookie,瀏覽器關(guān)閉就失效
可以通過 max_age 設(shè)置有效期, 單位是秒

resp = make_response("success") # 設(shè)置響應(yīng)體
resp.set_cookie("Itcast_1", "python_1", max_age=3600)

2.獲取cookie

獲取cookie,通過reques.cookies的方式, 返回的是一個字典,可以獲取字典里的相應(yīng)的值

cookie_1 = request.cookies.get("Itcast_1")

3.刪除cookie

這里的刪除只是讓cookie過期,并不是直接刪除cookie

刪除cookie,通過delete_cookie()的方式, 里面是cookie的名字

resp = make_response("del success") # 設(shè)置響應(yīng)體
resp.delete_cookie("Itcast1")

示例

from flask import Flask, make_response, request
app = Flask(__name__)
@app.route("/set_cookie")
def set_cookie():
  resp = make_response("success")
  '''
    設(shè)置cookie,默認有效期是臨時cookie,瀏覽器關(guān)閉就失效
    可以通過 max_age 設(shè)置有效期, 單位是秒
  '''''
  resp.set_cookie("Itcast_1", "python_1")
  resp.set_cookie("Itcast_2", "python_2")
  resp.set_cookie("Itcast_3", "python_3", max_age=3600)
  return resp
 
@app.route("/get_cookie")
def get_cookie():
  """
    獲取cookie,通過reques.cookies的方式,
    返回的是一個字典,可以用get的方式
  """
  cookie_1 = request.cookies.get("Itcast_1") # 獲取名字為Itcast_1對應(yīng)cookie的值
  return cookie_1
 
@app.route("/delete_cookie")
def delete_cookie():
  """
    刪除cookie,通過delete_cookie()的方式,
    里面是cookie的名字
    這里的刪除只是讓cookie過期,并不是直接刪除cookie
  """
  resp = make_response("del success")
  resp.delete_cookie("Itcast1")
  return resp
 
if __name__ == '__main__':
  app.run(debug=True)

到此這篇關(guān)于flask框架中的cookie和session使用的文章就介紹到這了,更多相關(guān)flask cookie和session內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Flask框架重定向,錯誤顯示,Responses響應(yīng)及Sessions會話操作示例
  • flask session組件的使用示例
  • Flask之flask-session的具體使用
  • flask使用session保存登錄狀態(tài)及攔截未登錄請求代碼

標簽:長春 漢中 河池 東莞 臨汾 廊坊 重慶 德宏

巨人網(wǎng)絡(luò)通訊聲明:本文標題《flask框架中的cookie和session使用》,本文關(guān)鍵詞  flask,框架,中的,cookie,和,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《flask框架中的cookie和session使用》相關(guān)的同類信息!
  • 本頁收集關(guān)于flask框架中的cookie和session使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    青川县| 靖西县| 尚义县| 寻甸| 芒康县| 克东县| 汶上县| 遵义县| 中西区| 西和县| 嘉兴市| 鄢陵县| 泰和县| 时尚| 诸城市| 色达县| 固安县| 阿拉善左旗| 神木县| 武邑县| 聂拉木县| 麟游县| 白银市| 伊宁县| 武宣县| 威宁| 清苑县| 潜江市| 常熟市| 彭州市| 石嘴山市| 原阳县| 格尔木市| 叶城县| 招远市| 万源市| 堆龙德庆县| 芜湖市| 密云县| 子长县| 文安县|