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 成功

 

posted @ 2021-09-25 10:07  小菠萝测试笔记  阅读(1757)  评论(0编辑  收藏  举报