查看一個網站的 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 成功