FastAPI -API Router的应用

APIRouter 是 FastAPI 框架中用于模块化组织路由的核心组件。你可以把它理解为一个"子应用"或"路由分组器"。

它的核心作用是帮助你将庞大的 API 接口拆分到不同的文件中进行管理,最后再统一挂载到主应用上,从而让项目结构更清晰、更易于维护。

为什么需要 APIRouter?

想象一下,你正在开发一个大型项目,如果不使用 APIRouter,所有的接口(如用户登录、商品管理、订单处理等)都会堆砌在 main.py 这一个文件中。随着项目扩大,这个文件会变得极其臃肿,查找和修改代码都会变得非常困难。

APIRouter 就像是为你提供了一个个"收纳盒",让你可以把不同功能的接口分门别类地放进去,最后再把所有"收纳盒"整齐地放进"大柜子"(主应用)里。

使用 APIRouter 的主要优势

  • 模块化拆分:将不同功能的接口(如用户、商品、订单)分到不同的文件中,代码结构清晰,符合单一职责原则。
  • 统一前缀管理 :通过 prefix 参数,可以为该组所有接口统一添加 URL 前缀(如 /users),无需在每个接口路径中重复书写。
  • 文档自动分组 :通过 tags 参数,可以让 FastAPI 自动生成的 Swagger 文档(/docs)中的接口按模块分组显示,更易读。
  • 模块级依赖注入:可以为整个路由组设置共同的依赖项(如身份验证),避免在每个接口中重复编写相同的逻辑。

如何使用 APIRouter

下面通过一个简单的例子来展示如何使用 APIRouter 来重构代码。

❌ 不使用 APIRouter (所有代码挤在 main.py)
复制代码
# main.py
from fastapi import FastAPI

app = FastAPI()

# 用户相关接口
@app.post("/users/login")
def login(): pass

@app.get("/users/info")
def get_user_info(): pass

# 商品相关接口
@app.post("/items/create")
def create_item(): pass

@app.get("/items/list")
def list_items(): pass
# 项目越大,main.py 越臃肿
✅ 使用 APIRouter (文件分离,结构清晰)

你可以将代码拆分成三个文件:

  1. routers/user.py (用户模块)

    复制代码
    from fastapi import APIRouter
    
    # 创建一个用户路由对象,并设置前缀和标签
    user_router = APIRouter(prefix="/users", tags=["用户管理"])
    
    @user_router.post("/login")
    def login():
        return {"msg": "登录成功"}
    
    @user_router.get("/info")
    def get_user_info():
        return {"name": "张三"}
  2. routers/item.py (商品模块)

    复制代码
    from fastapi import APIRouter
    
    # 创建一个商品路由对象
    item_router = APIRouter(prefix="/items", tags=["商品管理"])
    
    @item_router.post("/create")
    def create_item():
        return {"msg": "商品创建成功"}
    
    @item_router.get("/list")
    def list_items():
        return {"items": ["商品1", "商品2"]}
  3. main.py (主应用,只负责挂载路由)

    复制代码
    from fastapi import FastAPI
    from routers.user import user_router  # 导入用户路由
    from routers.item import item_router   # 导入商品路由
    
    app = FastAPI()
    
    # 把各个模块的路由「挂载」到主应用上
    app.include_router(user_router)
    app.include_router(item_router)

通过这种方式,你的项目结构会变得非常清晰,每个模块都独立在自己的文件中,极大地提升了代码的可读性和可维护性。

相关推荐
energy_DT14 分钟前
2026年海上钻井平台数字孪生平台:引领海洋能源数字化转型
前端
Eric_见嘉28 分钟前
在职前端 Agent 配置分享
前端·后端·agent
柚子81632 分钟前
break跳出语句块的神奇技巧
前端·javascript
计算机软件程序设计33 分钟前
Python Flask工程目录解读
python·flask·工程目录解读
Ares-Wang34 分钟前
Flask》》 Flask-OpenID 认证、 OpenID Connect (OIDC)
后端·python·flask
大卡片1 小时前
IO模型与并发服务器设计
运维·服务器·网络
m0_734949791 小时前
怎么利用Navicat进行调整备份文件压缩等级_详细配置与操作步骤
jvm·数据库·python
IpdataCloud2 小时前
IPv6商用数据的IP离线库能解决哪些业务问题?适用场景与接入指南
网络·网络协议·tcp/ip
m0_741173332 小时前
如何处理SQL中的NULL值_使用ISNULL或COALESCE函数
jvm·数据库·python
AC赳赳老秦2 小时前
OpenClaw进阶技巧:批量修改文件内容、替换关键词,解放双手
java·linux·人工智能·python·算法·测试用例·openclaw