当前位置: 首页 > news >正文

fastapi中的patch请求

目录

    • 示例
    • 测试
      • 使用 `curl` 访问:
      • 使用 `requests` 访问:
      • 预期返回:
    • 浏览器访问

示例

下面是一个使用 @app.patch("") 的 FastAPI 示例,该示例实现了一个简单的用户信息更新 API。我们使用 pydantic 定义数据模型,并使用 patch 方法部分更新用户信息。

from fastapi import FastAPI, HTTPException
from pydantic import BaseModel, Field
from typing import Optionalapp = FastAPI()# 模拟的用户数据
users_db = {1: {"name": "Alice", "age": 25, "email": "alice@example.com"},2: {"name": "Bob", "age": 30, "email": "bob@example.com"},
}# 请求模型,所有字段都是可选的
class UserUpdate(BaseModel):name: Optional[str] = Field(None, title="用户名")age: Optional[int] = Field(None, title="年龄", ge=0)email: Optional[str] = Field(None, title="邮箱")@app.patch("/users/{user_id}")
def update_user(user_id: int, user_update: UserUpdate):if user_id not in users_db:raise HTTPException(status_code=404, detail="User not found")# 更新用户信息existing_user = users_db[user_id]update_data = user_update.dict(exclude_unset=True)  # 仅获取传入的字段existing_user.update(update_data)return {"message": "User updated successfully", "user": existing_user}

这个示例:

  • 维护了一个 users_db 作为模拟数据库。
  • 使用 @app.patch("/users/{user_id}") 处理用户信息的部分更新。
  • 通过 exclude_unset=True 确保只更新请求体中提供的字段,而不会覆盖未提供的字段。

你可以运行它,并使用 PATCH 请求测试,例如:

{"name": "Charlie"
}

这将只更新用户的 name,而不会修改 ageemail

测试

你可以使用 curlhttpx 或者 requests 来访问 PATCH 端点。下面是一个示例:

使用 curl 访问:

curl -X PATCH "http://127.0.0.1:8000/users/1" \-H "Content-Type: application/json" \-d '{"name": "Charlie", "age": 28}'

这个请求会更新 id=1 的用户,将 name 改为 "Charlie",并将 age 改为 28


使用 requests 访问:

如果你在 Python 代码中调用,可以这样做:

import requestsurl = "http://127.0.0.1:8000/users/1"
payload = {"name": "Charlie", "age": 28}
headers = {"Content-Type": "application/json"}response = requests.patch(url, json=payload, headers=headers)print(response.json())  # 输出更新后的用户信息

预期返回:

{"message": "User updated successfully","user": {"name": "Charlie","age": 28,"email": "alice@example.com"}
}

可以看到,nameage 被成功更新,而 email 仍然保持原值。

你可以修改 payload 只提供部分字段,例如 {"email": "charlie@example.com"},就只会更新 email,其他字段不会改变。

另外,你可以在浏览器中访问 FastAPI 的 Swagger UI 或 Redoc 来测试 PATCH 请求,但 不能直接在地址栏访问,因为浏览器的地址栏只能发送 GET 请求,而 PATCH 请求需要使用 API 测试工具或 JavaScript 代码。

浏览器访问

FastAPI 自带了交互式文档,你可以在浏览器中打开:

  • Swagger UI: http://127.0.0.1:8000/docs
  • Redoc: http://127.0.0.1:8000/redoc

步骤:

  1. 启动 FastAPI 服务器(运行 uvicorn)。
  2. 在浏览器打开 http://127.0.0.1:8000/docs
  3. 找到 PATCH /users/{user_id} 端点,点击 “Try it out”
  4. 输入 user_id,在 Request body 里填入 JSON,例如:
    {"name": "Charlie","age": 28
    }
    
  5. 点击 “Execute” 发送请求,查看响应结果。

在这里插入图片描述

在这里插入图片描述

http://www.lryc.cn/news/545537.html

相关文章:

  • 系统架构设计师—计算机基础篇—计算机网络
  • MATLAB中asManyOfPattern函数用法
  • Kafka面试题及原理
  • Grok 3 AI 角色扮演提示词 化身顶级设计师
  • 从零开始设计一个完整的网站:HTML、CSS、PHP、MySQL 和 JavaScript 实战教程
  • CSS 对齐:深入理解与技巧实践
  • oracle游标为什么没有共享,统计一下原因
  • IDEA中.gitignore未忽略指定文件的问题排查与解决
  • 通往 AI 之路:Python 机器学习入门-语法基础
  • 形象生动讲解Linux 虚拟化 I/O
  • 6. Nginx 动静分离配置案例(附有详细说明+配图)
  • 数据集笔记:新加坡停车费
  • SQL经典题型
  • 最新Java面试题,常见面试题及答案汇总
  • 学习第九天-栈
  • Java基础关键_016_System 类
  • 计算机毕设JAVA——某高校宿舍管理系统(基于SpringBoot+Vue前后端分离的项目)
  • 【 实战案例篇三】【某金融信息系统项目管理案例分析】
  • vivado 避免本地时钟、创建输出时钟
  • 二十三种设计模式
  • uniapp 中引入使用uView UI
  • 用冒泡排序法模拟qsort函数
  • DCN讲解
  • nginx的作用和应用场景
  • [Lc滑动窗口_1] 长度最小的数组 | 无重复字符的最长子串 | 最大连续1的个数 III | 将 x 减到 0 的最小操作数
  • 基于python的网络爬虫爬取天气数据及可视化分析(Matplotlib、sk-learn等,包括ppt,视频)
  • 【缓存】缓存雪崩与缓存穿透:高并发系统的隐形杀手
  • HTML AI 编程助手
  • 李宏毅机器学习课程学习笔记04 | 浅谈机器学习-宝可梦、数码宝贝分类器
  • AIGC(生成式AI)试用 26 -- 跟着清华教程学习 - DeepSeek与AI幻觉