用flask開發個人部落格(7)—— flask中設定和獲取cookie

一 什麼是cookie

        什麼是cookie?如果單單從資料結構的角度來說,它可以被理解成用來儲存資料的一個dictionary,由一組組鍵值對組成.如果從作用上來說,我們知道Http協議是一種無狀態的協議.什麼叫無狀態呢,就是本次的客戶端請求不會保留上一次客戶端請求的狀態,簡單點說就是這樣會要求我們每次在瀏覽器中點開一個網站的連結都會輸一次賬戶和密碼.cookie就是用來解決這個問題的.

        為了解決上述問題,我們第一次登入web伺服器,服務端就會在它的響應中的Set-Cookie欄位中傳送一些鍵值對,這就包括一個Session ID以及其他一些資訊(也包括我們自定義的cookie中的鍵值對),並告訴客戶端在本地快取這個cookie.然後客戶端以後進行連結時每次都會傳送這個Session ID,伺服器一看是哪個Session ID就知道是哪個客戶端發起的連結了,就不會要求我們再次輸賬戶和密碼驗證了.

        我們在flask中自定義cookie,實際上就是在響應Response的Set-Cookie欄位中增加我們自定義的鍵值對.而獲取cookie,就是通過請求Request中通過鍵獲取其對應的值.

二 設定cookie

      通過響應物件的set_cookie方法我們可以設定自定義cookie:

@app.route('/set_cookie')
def set_cookie():
response=make_response('Hello World');
response.set_cookie('Name','Hyman')
return response

       我們還可以指定cookie的有效時長,下面的程式碼把有效時長設定成了30天.通常情況下,我們還可以在瀏覽器上設定cookie的有效時長,而且瀏覽器上配置的有效時長優先順序要高於我們在程式碼中設定的.

outdate=datetime.datetime.today()   datetime.timedelta(days=30)
response.set_cookie('Name','Hyman',expires=outdate)

三 獲取cookie

        我們可以使用Request物件cookies欄位的get方法來獲取我們所需要的cookie,下面的程式碼我們直接獲取cookie並返回給檢視函式:

@app.route('/get_cookie')
def get_cookie():
name=request.cookies.get('Name')
return name

       

        我們還可以在模板中獲取cookie,然後渲染模板.

test.html:

<h1>My name is {{request.cookies.get('Name')}}</h1>

渲染模板:

@app.route('/get_template')
def get_template():
return render_template('test.html')

四 刪除cookie

        共有三種方法可以刪除一個cookie:

(1) 可以通過在瀏覽器中設定來清除cookie.

(2) 使用Response的set_cookie進行清除

@app.route('/del_cookie')
def del_cookie():
response=make_response('delete cookie')
response.set_cookie('Name','',expires=0)
return response

(3)使用Response的 delete_cookie方法.

@app.route('/del_cookie2')
def del_cookie2():
response=make_response('delete cookie2')
response.delete_cookie('Name')
return response

Github位置:
https://github.com/HymanLiuTS/flaskTs

克隆本專案:
git clone git@github.com:HymanLiuTS/flaskTs.git
獲取本文原始碼:
git checkout FL07