查看一个网站的 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 成功