企业级FastAPI后端模板搭建(二)整合路由Router

添加项目设置

创建文件.env,在里面写入:

.env

python 复制代码
# 应用配置
VERSION=1.0.0
APP_TITLE=企业级FastAPI后端模板
PROJECT_NAME=fastapi-template
APP_DESCRIPTION=企业级FastAPI后端模板 - 开箱即用

# 应用配置
APP_ENV=development

# 调试模式 (生产环境设置为False)
DEBUG=True

安装依赖pydantic_settings,用于管理环境变量和配置

shell 复制代码
pip install pydantic_settings

创建settings/config.py文件,然后在里面编写:

python 复制代码
from pydantic_settings import BaseSettings, SettingsConfigDict

class Settings(BaseSettings):
  model_config = SettingsConfigDict(
    env_file=".env",
    env_file_encoding="utf-8",
    case_sensitive=True,
    extra="ignore",
  )
  VERSION: str = "0.1.0"
  APP_TITLE: str = "Vue FastAPI Admin"
  PROJECT_NAME: str = "Vue FastAPI Admin"
  APP_DESCRIPTION: str = "Description"
  DEBUG: bool = True
  APP_ENV: str = "development"
  
settings = Settings()

创建settings/__init__.py文件:

python 复制代码
from .config import settings as settings

整合路由Router

创建api/v1目录,在这个目录里面进行路由分发、参数验证。

然后在api/v1目录下创建auth/auth.py文件,在文件里面添加路由:

python 复制代码
import os
from datetime import UTC, datetime
from fastapi import APIRouter
from settings import settings

router = APIRouter()

@router.get("/health", summary="健康检查")
async def health_check():
  """系统健康检查"""
  return {
    "status": "healthy",
    "timestamp": datetime.now(UTC).isoformat(),
    "version": settings.VERSION,
    "environment": settings.APP_ENV,
    "service": "FastAPI Backend Template",
  }

@router.get("/version", summary="版本信息")
async def get_version():
  """获取API版本信息"""
  return {
    "version": settings.VERSION,
    "app_title": settings.APP_TITLE,
    "project_name": settings.PROJECT_NAME,
    "build": os.getenv("BUILD_NUMBER", "dev"),
    "commit": os.getenv("GIT_COMMIT", "unknown"),
    "python_version": os.getenv("PYTHON_VERSION", "3.11+"),
  }

创建api/v1/auth/__init__.py文件,代码如下:

python 复制代码
from fastapi import APIRouter

from .auth import router

auth_router = APIRouter()
auth_router.include_router(router, tags=["基础模块"])

__all__ = ["auth_router"]

创建api/v1/__init__.py文件,代码如下:

python 复制代码
from fastapi import APIRouter

from .auth import auth_router

v1_router = APIRouter()

v1_router.include_router(auth_router, prefix="/auth")

创建api/__init__.py文件,代码如下:

python 复制代码
from fastapi import APIRouter

from .v1 import v1_router

api_router = APIRouter()
api_router.include_router(v1_router, prefix="/v1")

__all__ = ["api_router"]

创建core/init_app.py文件,代码如下:

python 复制代码
from fastapi import FastAPI

from api import api_router

def register_routers(app: FastAPI, prefix: str = "/api"):
  app.include_router(api_router, prefix=prefix)

修改main.py文件,代码如下:

python 复制代码
from fastapi import FastAPI
from core.init_app import register_routers

app = FastAPI()

register_routers(app, prefix="/api")

然后可以通过访问http://127.0.0.1:8000/docs地址查看 FastAPI API 文档:

相关推荐
scan7241 小时前
根据上下文中的用户信息,切换提示词
python
不会C语言的男孩1 小时前
C++ Primer Plus 第13章:类继承
开发语言·c++
我材不敲代码1 小时前
Python基础: 函数超全详解:定义、参数、返回值、作用域与递归
开发语言·python·算法
志起计算机编程1 小时前
挖掘单节点Clickhouse极致性能上限
服务器·开发语言·python
程序员杰哥1 小时前
接口自动化测试:多环境配置实战
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
Reisentyan1 小时前
[Pro]GoLang Learn Data Day 5
开发语言·后端·golang
zhangfeng11331 小时前
华为昇腾910A NPU 的模型加密方案 ASCEND-CC
开发语言·人工智能·神经网络·transformer
zh路西法1 小时前
【OpenCV无人机光流速度估计】基于Farneback稠密光流方法的无人机速度估计
人工智能·python·opencv·计算机视觉·无人机
聆风吟º1 小时前
【Python编程日志】Python基础语法:常量 | 表达式 | 变量
开发语言·python·变量·常量·表达式