FastAPI中路径参数,查询参数,请求体参数之间的区别

1. 路径参数

  • 数据位置:直接嵌入在URL的路径中。

  • 用途 :通常用于定位特定的资源。它是必填的,因为它是URL结构的一部分。

  • 示例/users/{user_id}

python 复制代码
from fastapi import FastAPI

app = FastAPI()

# 假设我们要获取ID为123的用户
# 请求地址:/users/123
@app.get("/users/{user_id}")
async def read_user(user_id: int):  # user_id 是路径参数
    return {"user_id": user_id}

2. 查询参数

  • 数据位置 :URL中 ? 后面的部分,以键值对形式存在。

  • 用途 :通常用于过滤、排序、分页 或提供可选的额外指令。它是可选的(通常有默认值),或者是非必须的。

  • 示例/users?page=2&limit=10

python 复制代码
from fastapi import FastAPI

app = FastAPI()

fake_items_db = [{"item_name": "Foo"}, {"item_name": "Bar"}, {"item_name": "Baz"}]

# 请求地址:/items?skip=0&limit=10
@app.get("/items/")
async def list_items(skip: int = 0, limit: int = 10):  # skip 和 limit 是查询参数
    return fake_items_db[skip : skip + limit]

# 可选参数的例子:/users?name=John
@app.get("/users/")
async def get_user(name: str = None):  # name 是可选查询参数
    if name:
        return f"查询名为 {name} 的用户"
    return "返回所有用户"

3. 请求体参数

  • 数据位置 :HTTP请求的**Body(主体)**中。

  • 用途 :通常用于提交创建或更新资源的数据。由于Body可以传输复杂的结构,它适合传输较复杂的数据(如嵌套的JSON对象)。

  • 示例 :在POST请求的Body中放置 {"name": "Foo", "price": 45.2}

python 复制代码
from fastapi import FastAPI
from pydantic import BaseModel  # 需要定义数据模型

app = FastAPI()

# 1. 定义一个 Pydantic 模型,描述请求体的结构
class Item(BaseModel):
    name: str
    price: float
    is_offer: bool = False  # 可选字段,默认False

# 2. 在路径操作函数中使用该模型
@app.post("/items/")
async def create_item(item: Item):  # item 是请求体参数
    # FastAPI 会读取请求体,并验证是否符合 Item 模型的格式
    return {"item_name": item.name, "item_price": item.price}
相关推荐
带娃的IT创业者14 小时前
WeClaw 离线消息队列实战:异步任务队列如何保证在服务器宕机时不丢失任何一条 AI 回复?
运维·服务器·人工智能·python·websocket·fastapi·实时通信
龙腾AI白云21 小时前
数字孪生底层逻辑和技术
深度学习·django·flask·fastapi·tornado
理性的曜2 天前
VoloData——基于LangChain的智能数据分析系统
人工智能·vscode·数据分析·npm·reactjs·fastapi·ai应用
带娃的IT创业者2 天前
Weclaw 请求路由实战:一个 request_id 如何在 800 个并发连接中精准找到目标浏览器?
python·websocket·fastapi·架构设计·实时通信·openclaw·weclaw
带娃的IT创业者2 天前
WeClaw 心跳与重连实战:指数退避算法如何让 WebSocket 在弱网环境下的连接成功率提升 67%?
python·websocket·网络协议·算法·fastapi·实时通信
理性的曜2 天前
AI语音通话系统设计思路:从语音输入到智能回复
人工智能·python·websocket·fastapi
带娃的IT创业者2 天前
WeClaw WebSocket 路由实战:BridgeConnectionManager 如何用四层映射在 800 个连接中实现毫秒级消息转发?
网络·python·websocket·网络协议·fastapi·实时通信
ewboYang2 天前
自学全栈搭建python [fastapi] + uniapp [vue3+ts]项目
python·uni-app·fastapi
PD我是你的真爱粉2 天前
Django MVT vs FastAPI DDD架构
架构·django·fastapi