0

0

使用 FastAPI 构建 Todo API 的部分:分步指南

王林

王林

发布时间:2024-08-28 09:03:12

|

334人浏览过

|

来源于dev.to

转载

使用 fastapi 构建 todo api 的部分:分步指南

使用 fastapi 构建 todo api:分步指南

代码可以在这里找到:github - jamesbmour/blog_tutorials:

一、简介

在上一篇文章中,我们介绍了fastapi并建立了基本的项目结构。现在,我们将更进一步,构建一个功能性的 todo api。在本教程结束时,您将拥有一个可以创建、读取、更新和删除待办事项的工作后端。

我们将涵盖的内容:

  • 设计 todo 数据模型
  • 实现crud操作
  • 创建 api 端点
  • 添加输入验证和错误处理
  • 测试api
  • 重构和组织代码

二.设计 todo 数据模型

为了管理待办事项,我们必须定义一个表示待办事项的数据模型。 fastapi 使用 pydantic 模型来验证和解析数据,因此我们将在这里利用它。

a. 定义 todo 模式

我们将使用 pydantic 创建两个模型:

  • todocreate:用于创建或更新待办事项时的输入数据。
  • todo:用于完整的待办事项,包括 id 和created_at 等字段。
from pydantic import basemodel
from typing import optional
from datetime import datetime

class todocreate(basemodel):
    title: str
    description: optional[str] = none
    completed: bool = false

class todo(basemodel):
    id: str
    title: str
    description: optional[str] = none
    completed: bool
    created_at: datetime

b. 解释字段

  • id:每个待办事项的唯一标识符。
  • 标题:待办事项的主要内容。
  • 描述:其他详细信息(可选)。
  • completed:待办事项的布尔状态(无论是否完成)。
  • created_at:指示待办事项创建时间的时间戳。

三.为 todos 创建 crud 操作

crud 代表创建、读取、更新和删除——管理数据的四个基本操作。在本教程中,我们将使用内存数据库(一个简单的列表)来实现这些操作。

a. 设置内存数据库

我们将使用一个列表来存储我们的待办事项。为了简单起见,我们还将添加一些示例待办事项。

from uuid import uuid4
from datetime import datetime

todos = [
    {
        "id": str(uuid4()),
        "title": "learn fastapi",
        "description": "go through the official fastapi documentation and tutorials.",
        "completed": false,
        "created_at": datetime.now(),
    },
    {
        "id": str(uuid4()),
        "title": "build a todo api",
        "description": "create a rest api for managing todo items using fastapi.",
        "completed": false,
        "created_at": datetime.now(),
    },
    {
        "id": str(uuid4()),
        "title": "write blog post",
        "description": "draft a blog post about creating a todo api with fastapi.",
        "completed": false,
        "created_at": datetime.now(),
    },
]

b. 实现辅助函数

我们将实现一个简单的辅助函数来通过 id 查找待办事项。

def get_todo_by_id(todo_id: str):
    for todo in todos:
        if todo["id"] == todo_id:
            return todo
    return none

四.实施 api 端点

a. 创建新的待办事项

post 端点允许用户创建新的待办事项。

@app.post("/todos/", response_model=todo)
def create_todo(todo: todocreate):
    new_todo = todo(
        id=str(uuid4()),
        title=todo.title,
        description=todo.description,
        completed=todo.completed,
        created_at=datetime.now()
    )
    todos.append(new_todo.dict())
    return new_todo

b. 检索所有待办事项

get 端点从我们的内存数据库中检索所有待办事项。

@app.get("/todos/", response_model=list[todo])
def get_all_todos():
    return todos

c. 检索单个待办事项

get 端点允许通过 id 检索单个待办事项。

@app.get("/todos/{todo_id}", response_model=todo)
def get_todo(todo_id: str):
    todo = get_todo_by_id(todo_id)
    if not todo:
        raise httpexception(status_code=404, detail="todo not found")
    return todo

d. 更新待办事项

put 端点允许用户更新现有的待办事项。

php中级教程之ajax技术
php中级教程之ajax技术

AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。它不是新的编程语言,而是一种使用现有标准的新方法,最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容,不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。《php中级教程之ajax技术》带你快速

下载
@app.put("/todos/{todo_id}", response_model=todo)
def update_todo(todo_id: str, todo_data: todocreate):
    todo = get_todo_by_id(todo_id)
    if not todo:
        raise httpexception(status_code=404, detail="todo not found")
    todo["title"] = todo_data.title
    todo["description"] = todo_data.description
    todo["completed"] = todo_data.completed
    return todo(**todo)

e. 删除待办事项

delete 端点允许用户通过 id 删除待办事项。

@app.delete("/todos/{todo_id}")
def delete_todo(todo_id: str):
    todo = get_todo_by_id(todo_id)
    if not todo:
        raise httpexception(status_code=404, detail="todo not found")
    todos.remove(todo)
    return {"detail": "todo deleted successfully"}

v. 添加输入验证和错误处理

a. 使用 pydantic 进行输入验证

fastapi 自动根据我们定义的 pydantic 模型验证输入数据。这确保数据在处理之前符合我们预期的模式。

b. 自定义错误处理

我们可以通过添加异常处理程序来自定义错误响应。

@app.exception_handler(HTTPException)
def http_exception_handler(request, exc: HTTPException):
    return JSONResponse(
        status_code=exc.status_code,
        content={"detail": exc.detail},
    )

六.测试 api

fastapi 附带交互式 swagger ui 文档,可以轻松测试您的 api 端点。只需运行应用程序并在浏览器中导航至 /docs 即可。

测试实例

  • 创建待办事项:通过创建新的待办事项来测试 post 端点。
  • 检索待办事项:使用 get 端点获取所有待办事项或按 id 获取特定待办事项。
  • 更新和删除:测试 put 和 delete 端点以更新或删除待办事项。

七.重构和组织代码

随着应用程序的增长,保持代码的组织性至关重要。这里有一些提示:

a. 将模型移动到单独的文件

您可以将 pydantic 模型移动到 models.py 文件中,以保持主应用程序文件干净。

b. 为 todo 端点创建路由器

考虑为与待办事项相关的端点创建一个单独的路由器,特别是随着您的 api 的增长。

八.下一步

在下一篇文章中,我们将把一个真实的数据库(如 sqlite 或 postgresql)集成到我们的 fastapi 应用程序中。我们还将研究用户身份验证和更高级的功能。

建议的改进:

  • 为 get 端点添加过滤和分页。
  • 实现用户身份验证来管理个人待办事项。

九.结论

在本教程中,我们使用 fastapi 构建了一个简单的 todo api。我们首先设计一个数据模型,实现 crud 操作,并创建端点来管理待办事项。我们还涉及输入验证、错误处理和测试。有了这个基础,您可以进一步扩展 api 或将其与前端集成以创建成熟的应用程序。

如果你想支持我的写作或给我买啤酒:
https://buymeacoffee.com/bmours

相关专题

更多
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API

Python FastAPI 异步开发利用 async/await 关键字,通过定义异步视图函数、使用异步数据库库 (如 databases)、异步 HTTP 客户端 (如 httpx),并结合后台任务队列(如 Celery)和异步依赖项,实现高效的 I/O 密集型 API,显著提升吞吐量和响应速度,尤其适用于处理数据库查询、网络请求等耗时操作,无需阻塞主线程。

27

2025.12.22

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

180

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

278

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

253

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

121

2025.08.07

数据库Delete用法
数据库Delete用法

数据库Delete用法:1、删除单条记录;2、删除多条记录;3、删除所有记录;4、删除特定条件的记录。更多关于数据库Delete的内容,大家可以访问下面的文章。

269

2023.11.13

drop和delete的区别
drop和delete的区别

drop和delete的区别:1、功能与用途;2、操作对象;3、可逆性;4、空间释放;5、执行速度与效率;6、与其他命令的交互;7、影响的持久性;8、语法和执行;9、触发器与约束;10、事务处理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

209

2023.12.29

postgresql常用命令
postgresql常用命令

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。本专题为大家提供postgresql相关的文章、下载、课程内容,供大家免费下载体验。

158

2023.10.10

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.7万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号