fastapi-路由

本文介绍了FastAPI的APIRouter的使用,包括参数介绍和方法介绍。APIRouter用于组织应用程序的不同部分,提供如prefix、tags、dependencies等参数,以及route()、add_api_route()等方法来定义和管理路由。此外,还探讨了FastAPI的其他特性,如on_startup和on_shutdown事件处理,以及如何在Swagger UI中展示和配置路由。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

FastAPIAPIRouter是一个用于将不同功能模块的端点进行划分的工具,类似于Flask中的蓝图(Blueprint)。通过APIRouter,你可以将应用程序的不同部分组织成独立的路由模块,从而提高代码的可读性和可维护性。

APIRouter允许你在不同的模块中定义路由操作,然后将它们挂载到全局应用程序路由中。这样,你可以将相关的路由操作组织在一起,使代码结构更加清晰,同时便于管理和维护

APIRouter使用

假设你在routers/router_1.py文件下,定义了以下这么一个非常简单的APIRouter

from fastapi import APIRouter

router = APIRouter()

@router.get("/get")
async def get():
    return {
   'api': 'get'}
    
@router.post("/post")
async def post():
    return {
   'api': 'post'}
    
@router.put("/put")
async def put():
    return {
   'api': 'put'}
    
@router.patch("/patch")
async def patch():
    return {
   'api': 'patch'}
    
@router.delete("/delete")
async def delete():
    return {
   'api': 'delete'}

定义好APIRouter之后,需要在应用程序中将其添加进来,如下:

from fastapi import FastAPI
from routers.router_1 import router

app = FastAPI()
app.include_router(router)

当我们添加一组路由时,我们需要给这些路由加一个前缀,表示这是同一批路由。我们可以用到prefix参数,如下:

from fastapi import APIRouter

router = APIRouter(prefix="/apis")

@router.get("/get")
async def get():
    return {
   'api': 'get'}

如此,我们可以通过http://localhost:8000/apis/get来请求该路由。

参数介绍

APIRouter常见参数如下:

prefix

prefix为API前缀,接收一个str数据

tags

tags为路由设置标签,接收一个List[str]或者List[Enum]类型

router = APIRouter(tags=["home", "user"])

@router.get("/home")
async def home():
    return {
   "code": 1}

在Swagger UI中效果如下:

piAMOfS.png

dependencies

dependencies为依赖项,可用来做一些额外操作(例如权限验证等),接收一个Sequence[params.Depends]类型。如下:

from fastapi import Header
from fastapi import Depends
from fastapi import APIRouter

async def token_validation(authorization: str = Header(...)):
    print(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值