FastAPI(17)- 詳解 Cookie,獲取 Cookies
阿新 • • 發佈:2022-01-05
FastAPI(17)- 詳解 Cookie,獲取 Cookies
檢視一個網站的 Cookies
進到某個網站,右鍵檢查元素;或者直接 F12
找到 Application-Cookies 就能看到啦
FastAPI 提供的 Cookie
- Cookie 是 Path 和 Query 的“姐妹”類
- 它也繼承自相同的通用 Param 類
- 注意:從 fastapi 匯入 Query、Path、Cookie 等時,這些實際上是返回特殊類的函式
手動給瀏覽器設定 Cookie
也是開啟 F12 開發者工具,在console視窗輸入
document.cookie="name=test_cookie"
讀取 Cookie
#!usr/bin/env python
# -*- coding:utf-8 _*-
"""
# author: 小菠蘿測試筆記
# blog: https://www.cnblogs.com/poloyy/
# time: 2021/9/21 2:39 下午
# file: 15_cookies.py
"""
from typing import Optional
import uvicorn
from fastapi import Cookie, FastAPI
app = FastAPI()
@app.get("/items/")
async def read_items (name: Optional[str] = Cookie(None)):
return {"name": name}
if __name__ == "__main__":
uvicorn.run(app="15_cookies:app", host="127.0.0.1", port=8080, reload=True, debug=True)
重點:函式引數的命名很重要,需要和 Cookie 的 Name 對應上才能拿到對應的 Cookie 哦
瀏覽器訪問該介面
因為上面是手動在瀏覽器加的 Cookie,所以只能從瀏覽器測試該介面
返回 Set-Cookie
在正常的網站中,如果登入成功或者鑑權成功,伺服器返回的響應會帶上 Set-Cookie,表示瀏覽器需要設定的一些 Cookie
那麼 FastAPI 是如何返回帶有 Set-Cookie 的響應呢?
from fastapi.responses import JSONResponse
@app.get("/cookie/")
def Login():
content = {"message": "yy_cookie"}
response = JSONResponse(content=content)
response.set_cookie(key="username", value="zlkt")
return response
這裡會用到 FastAPI 提供的響應模型,後面會詳解,這裡先做了解
方便演示,這裡用 get 請求
瀏覽器訪問該介面
設定 Cookie 成功