OpenAPI 转 FastAPI 项目教程
项目介绍
openapi-to-fastapi
是一个开源项目,旨在从多个 OpenAPI 规范生成 FastAPI 路由。该项目最初是为了解决从多个 OpenAPI 规范创建 API 并确保传入请求和传出响应与规范中定义的模型一致的问题。尽管该项目目前仍处于实验阶段,并且有一些技术限制,但它为需要从 OpenAPI 规范生成 FastAPI 路由的开发者提供了一个可行的解决方案。
项目快速启动
安装
首先,通过 pip 安装 openapi-to-fastapi
包:
pip install openapi-to-fastapi
生成 FastAPI 路由
以下是一个简单的示例,展示如何从 OpenAPI 规范生成 FastAPI 路由:
from pathlib import Path
from openapi_to_fastapi.routes import SpecRouter
# 指定 OpenAPI 规范文件的路径
specs = Path("/path/to/specs")
# 创建 SpecRouter 实例
router = SpecRouter(specs).to_fastapi_router()
将路由集成到 FastAPI 应用
将生成的路由集成到 FastAPI 应用中:
from fastapi import FastAPI
app = FastAPI()
app.include_router(router)
应用案例和最佳实践
自定义路由处理
在大多数情况下,创建一个没有业务逻辑的 API 是没有意义的。以下是如何定义自定义路由处理的示例:
from fastapi import Header, HTTPException
from openapi_to_fastapi.routes import SpecRouter
spec_router = SpecRouter("/path/to/specs")
# 默认处理所有 POST 端点
@spec_router.post()
def hello_world(params, x_my_token: str = Header()):
if x_my_token != "my_token":
raise HTTPException(status_code=403, detail="Sorry")
return {"Hello": "World"}
# 特定端点处理 "/pet" 路由
@spec_router.post("/pet")
def create_pet(params):
pet = db.make_pet(name=params['name'])
return pet.to_dict()
router = spec_router.to_fastapi_router()
自动文档
FastAPI 的一个强大功能是自动生成 API 文档。openapi-to-fastapi
可以自动处理请求和响应模型,但需要为每个端点分配一个名称以显示文档:
from openapi_to_fastapi.routes import SpecRouter
spec_router = SpecRouter("/path/to/specs")
@spec_router.post(
"/pet",
name="Create a pet",
description="Create a pet",
response_description="A Pet",
tags=["pets"]
)
def create_pet(params):
return []
典型生态项目
FastAPI
FastAPI 是一个现代、快速(高性能)的 web 框架,用于构建 API,基于标准的 Python 类型提示。它支持自动生成 OpenAPI 规范,并且与 openapi-to-fastapi
项目紧密集成。
Pydantic
Pydantic 是一个数据验证和设置管理库,使用 Python 类型提示进行验证。FastAPI 广泛使用 Pydantic 进行数据模型定义和验证,openapi-to-fastapi
项目也依赖于 Pydantic 来处理请求和响应模型。
Swagger UI
Swagger UI 是一个用于可视化和与 API 规范交互的工具。FastAPI 自动生成的 OpenAPI 规范可以通过 Swagger UI 进行可视化,使得 API 的测试和文档编写更加方便。
通过结合这些生态项目,openapi-to-fastapi
提供了一个强大的工具集,用于从 OpenAPI 规范快速生成功能丰富的 FastAPI 应用。