
关于
使用 FastAPI 构建生产级 REST API,涵盖依赖注入、中间件、后台任务和 OpenAPI 文档。
name: python-fastapi-ops description: "FastAPI Web 框架模式。触发条件:fastapi、api endpoint、dependency injection、pydantic model、openapi、swagger、starlette、async api、rest api、uvicorn。" license: MIT compatibility: "FastAPI 0.100+, Pydantic v2, Python 3.10+。生产环境需要 uvicorn。" allowed-tools: "Read Write Bash" metadata: author: claude-mods depends-on: python-typing-ops, python-async-ops related-skills: python-database-ops, python-observability-ops, python-pytest-ops
FastAPI 模式
使用 FastAPI 进行现代异步 API 开发。
基础应用
from fastapi import FastAPI
from contextlib import asynccontextmanager
@asynccontextmanager
async def lifespan(app: FastAPI):
"""Application lifespan - startup and shutdown."""
# Startup
app.state.db = await create_db_pool()
yield
# Shutdown
await app.state.db.close()
app = FastAPI(
title="My API",
version="1.0.0",
lifespan=lifespan,
)
@app.get("/")
async def root():
return {"message": "Hello World"}
请求/响应模型
from pydantic import BaseModel, Field, EmailStr
from datetime import datetime
class UserCreate(BaseModel):
"""Request model with validation."""
name: str = Field(..., min_length=1, max_length=100)
email: EmailStr
age: int = Field(..., ge=0, le=150)
class UserResponse(BaseModel):
"""Response model."""
id: int
name: str
email: EmailStr
created_at: datetime
model_config = {"from_attributes": True} # Enable ORM mode
@app.post("/users", response_model=UserResponse, status_code=201)
async def create_user(user: UserCreate):
db_user = await create_user_in_db(user)
return db_user
路径和查询参数
from fastapi import Query, Path
from typing import Annotated
@app.get("/users/{user_id}")
async def get_user(
user_id: Annotated[int, Path(..., ge=1, description="User ID")],
):
return await fetch_user(user_id)
@app.get("/users")
async def list_users(
skip: Annotated[int, Query(ge=0)] = 0,
limit: Annotated[int, Query(ge=1, le=100)] = 10,
search: str | None = None,
):
return await fetch_users(skip=skip, limit=limit, search=search)
依赖注入
from fastapi import Depends
from typing import Annotated
async def get_db():
"""Database session dependency."""
async with async_session() as session:
yield session
async def get_current_user(
token: Annotated[str, Depends(oauth2_scheme)],
db: Annotated[AsyncSession, Depends(get_db)],
) -> User:
"""Authenticate and return current user."""
user = await authenticate_token(db, token)
if not user:
raise HTTPException(status_code=401, detail="Invalid token")
return user
# Annotated types for reuse
DB = Annotated[AsyncSession, Depends(get_db)]
CurrentUser = Annotated[User, Depends(get_current_user)]
@app.get("/me")
async def get_me(user: CurrentUser):
return user
异常处理
from fastapi import HTTPException
from fastapi.responses import JSONResponse
# 内置 HTTP 异常
@app.get("/items/{item_id}")
async def get_item(item_id: int):
item = await fetch_item(item_id)
if not item:
raise HTTPException(status_code=404, detail="Item not found")
return item
# 自定义异常处理器
class ItemNotFoundError(Exception):
def __init__(self, item_id: int):
self.item_id = item_id
@app.exception_handler(ItemNotFoundError)
async def item_not_found_handler(request, exc: ItemNotFoundError):
return JSONResponse(
status_code=404,
content={"detail": f"Item {exc.item_id} not found"},
)
路由组织
from fastapi import APIRouter
# users.py
router = APIRouter(prefix="/users", tags=["users"])
@router.get("/")
async def list_users():
return []
@router.get("/{user_id}")
async def get_user(user_id: int):
return {"id": user_id}
# main.py
from app.routers import users, items
app.include_router(users.router)
app.include_router(items.router, prefix="/api/v1")
快速参考
| 功能 | 用法 |
|---------|-------|
| 路径参数 | @app.get("/items/{id}") |
| 查询参数 | def f(q: str = None) |
| 请求体 | def f(item: ItemCreate) |
| 依赖 | Depends(get_db) |
| 认证 | Depends(get_current_user) |
| 响应模型 | response_model=ItemResponse |
| 状态码 | status_code=201 |
附加资源
./references/dependency-injection.md- 高级 DI 模式、作用域、缓存./references/middleware-patterns.md- 中间件链、CORS、错误处理./references/validation-serialization.md- Pydantic v2 模式、自定义验证器./references/background-tasks.md- 后台任务、异步 Worker、调度
脚本
./scripts/scaffold-api.sh- 生成 API 端点脚手架
资产
./assets/fastapi-template.py- 生产就绪的 FastAPI 应用骨架
兼容工具
Claude CodeCursorGitHub Copilot
标签
后端开发

