FastAPI开发文档教程-中间件

admin 2026-01-10 10:56:22 编程 来源:ZONE.CI 全球网 0 阅读模式
  • 创建中间件
    • response 的前和后
  • 其他中间件

    你可以向 FastAPI 应用添加中间件.

    “中间件”是一个函数,它在每个请求被特定的路径操作处理之前,以及在每个响应返回之前工作.

    • 它接收你的应用程序的每一个请求.
    • 然后它可以对这个请求做一些事情或者执行任何需要的代码.
    • 然后它将请求传递给应用程序的其他部分 (通过某种路径操作).
    • 然后它获取应用程序生产的响应 (通过某种路径操作).
    • 它可以对该响应做些什么或者执行任何需要的代码.
    • 然后它返回这个 响应.

    技术细节

    如果你使用了 yield 关键字依赖, 依赖中的退出代码将在执行中间件执行.

    如果有任何后台任务(稍后记录), 它们将在执行中间件运行.

    创建中间件

    要创建中间件你可以在函数的顶部使用装饰器 @app.middleware("http").

    中间件参数接收如下参数:

    • request.
    • 一个函数 call_next 它将接收 request 作为参数.
      • 这个函数将 request 传递给相应的 路径操作.
      • 然后它将返回由相应的路径操作生成的 response.
    • 然后你可以在返回 response 前进一步修改它.

    `import time

    from fastapi import FastAPI, Request

    app = FastAPI()

    @app.middleware(“http”) async def add_process_time_header(request: Request, call_next): start_time = time.time() response = await call_next(request) process_time = time.time() - start_time response.headers[“X-Process-Time”] = str(process_time) return response`

    Tip

    请记住可以 用’X-‘ 前缀添加专有自定义请求头.

    但是如果你想让浏览器中的客户端看到你的自定义请求头, 你需要把它们加到 CORS 配置 (CORS (Cross-Origin Resource Sharing)) 的 expose_headers 参数中,在 Starlette’s CORS docs文档中.

    技术细节

    你也可以使用 from starlette.requests import Request.

    FastAPI 为了开发者方便提供了该对象. 但其实它直接来自于 Starlette.

    response 的前和后

    在任何路径操作收到request前,可以添加要和请求一起运行的代码.

    也可以在响应生成但是返回之前添加代码.

    例如你可以添加自定义请求头 X-Process-Time 包含以秒为单位的接收请求和生成响应的时间:

    `import time

    from fastapi import FastAPI, Request

    app = FastAPI()

    @app.middleware(“http”) async def add_process_time_header(request: Request, call_next): start_time = time.time() response = await call_next(request) process_time = time.time() - start_time response.headers[“X-Process-Time”] = str(process_time) return response`

    其他中间件

    你可以稍后在 Advanced User Guide: Advanced Middleware阅读更多关于中间件的教程.

    你将在下一节中学习如何使用中间件处理 CORS .

    FastAPI开发文档教程-中间件 编程

    FastAPI开发文档教程-中间件

    创建中间件在 response 的前和后其他中间件你可以向 FastAPI 应用添加中间件. “中间件”是一个函数,它在每个请求被特定的路径操作处理之前,以及在每个响应返回之前工作.它接收你的应用程序
    FastAPI开发文档教程-依赖项 编程

    FastAPI开发文档教程-依赖项

    什么是「依赖注入」第一步创建依赖项导入 Depends声明依赖项要不要使用 async?与 OpenAPI 集成简单用法FastAPI 插件FastAPI 兼容性简单而强大与 OpenAPI 集成Fa
    FastAPI开发文档教程-JSON兼容编码器 编程

    FastAPI开发文档教程-JSON兼容编码器

    使用jsonable_encoder在某些情况下,您可能需要将数据类型(如Pydantic模型)转换为与JSON兼容的数据类型(如dict、list等)。 比如,如果您需要将其存储在数据库中。 对于这
    评论:0   参与:  0