FastAPI之响应状态码

本文详细讲解了如何在FastAPI中设置默认和动态响应状态码,以及如何通过HTTPException处理错误,以优化API设计。

使用FastAPI自定义响应状态码

FastAPI 是一个现代、快速的 web 框架,用于构建API服务,它允许你通过Python 3.6及以上版本进行编程。一个重要的API设计是返回合适的响应状态码,这可以使得客户端理解服务端的处理结果。本教程将向你展示如何在FastAPI中使用和自定义响应状态码。

状态码概览

HTTP状态码是服务器用来告知客户端关于请求的处理情况的3位数字代码。这些状态码分为五个类别:

  • 1xx (信息): 请求已被接受,继续处理。
  • 2xx (成功): 请求已成功被服务器接收、理解、并接受。
  • 3xx (重定向): 需要后续操作才能完成这一请求。
  • 4xx (客户端错误): 请求包含语法错误或无法被执行。
  • 5xx (服务器错误): 服务器在处理请求的时候发生了错误。

FastAPI中设置响应状态码

FastAPI 允许在路径操作中设置响应状态码。以下是一些基本示例。

设置默认响应状态码

你可以为路径操作设置默认的响应状态码,如下:

from fastapi import FastAPI, status

app = FastAPI()

@app.post("/items/", status_code=status.HTTP_201_CREATED)
async def create_item(name: str):
    return {"name": name}

在上述示例中,当你向 /items/ 端点发送 POST 请求时,无论何时,只要没有异常,它都会返回 201 Created 状态码。

使用响应参数设置状态码

也可以在函数内部动态设置状态码,通过 Response 对象的 status_code 属性:

from fastapi import FastAPI, Response, status

app = FastAPI()

@app.post("/items/")
async def create_item(name: str, response: Response):
    response.status_code = status.HTTP_202_ACCEPTED
    return {"name": name}

在这个例子中,我们将响应状态码设置为 202 Accepted
测试结果
在这里插入图片描述

使用HTTPException定义错误状态码

你可能需要通知客户端错误发生,比如用户请求一个不存在的项。在FastAPI中,你可以通过抛出 HTTPException 来实现。

from fastapi import FastAPI, HTTPException, status

app = FastAPI()

fake_db = {"foo": "bar"}

@app.get("/items/{item_id}")
async def read_item(item_id: str):
    if item_id not in fake_db:
        raise HTTPException(status_code=404, detail="Item not found")
    return {"item": fake_db[item_id]}

在这个例子中,如果请求的 item_id 不存在于数据库中,我们抛出一个 HTTPException,状态码为 404 Not Found
测试结果:
在这里插入图片描述

结论

使用合适的响应状态码是API设计的一个重要方面,它可以提升API的可用性并且帮助客户端理解请求的处理情况。FastAPI提供了简单直观的方式来设置和自定义响应状态码。通过本教程的示例,你现在应该能够在你的API中有效管理响应状态码了。

注意:务必记住,正确使用状态码可以帮助客户端更好地处理不同情况,改善用户体验。

FastAPI 中,状态码的获取和设置通常通过 `response` 参数或返回 `Response` 对象来实现。以下是一些常用的方法和技巧: ### 获取响应状态码 1. **使用 `response` 参数控制状态码** 在定义路由时,可以通过 `response` 参数指定响应模型,并结合 `status_code` 来设置特定的状态码。例如,在处理成功请求时返回 `200 OK`,在发生错误时返回 `404 Not Found`。 ```python from fastapi import FastAPI, status from fastapi.responses import JSONResponse app = FastAPI() @app.get("/example") async def example_endpoint(): return JSONResponse(content={"message": "Success"}, status_code=status.HTTP_200_OK) ``` 2. **通过异常处理获取状态码** 使用 `HTTPException` 可以抛出带有特定状态码的异常,FastAPI 会自动捕获并返回对应的 HTTP 响应。 ```python from fastapi import FastAPI, HTTPException app = FastAPI() @app.get("/items/{item_id}") async def read_item(item_id: int): if item_id not in items: raise HTTPException(status_code=404, detail="Item not found") return {"item_id": item_id} ``` 3. **自定义中间件中获取状态码** 在自定义的 `ResponseMiddleware` 中,可以通过拦截请求和响应来读取或修改状态码。例如,记录每个请求的响应状态码。 ```python from fastapi import Request, FastAPI from fastapi.middleware import Middleware from fastapi.middleware.base import BaseHTTPMiddleware class ResponseMiddleware(BaseHTTPMiddleware): async def dispatch(self, request: Request, call_next): response = await call_next(request) print(f"Response status code: {response.status_code}") # 获取状态码[^1] return response app = FastAPI() app.add_middleware(ResponseMiddleware) ``` 4. **直接操作 `Response` 对象** 如果需要更精细地控制响应内容和状态码,可以直接返回 `Response` 子类(如 `JSONResponse`, `PlainTextResponse` 等)的实例。 ```python from fastapi import FastAPI from fastapi.responses import Response app = FastAPI() @app.get("/custom-response") async def custom_response(): return Response(content="Custom content", status_code=201) # 自定义状态码[^2] ``` ### 示例:获取状态码的完整示例 ```python from fastapi import FastAPI, Request, Response, HTTPException from fastapi.middleware.base import BaseHTTPMiddleware class StatusLoggingMiddleware(BaseHTTPMiddleware): async def dispatch(self, request: Request, call_next): response = await call_next(request) print(f"Request path: {request.url.path}, Status Code: {response.status_code}") # 日志记录状态码[^1] return response app = FastAPI() app.add_middleware(StatusLoggingMiddleware) @app.get("/success") async def success(): return {"message": "OK"} # 默认返回 200 状态码 @app.get("/error") async def error(): raise HTTPException(status_code=400, detail="Bad Request") # 抛出 400 错误[^2] @app.get("/custom-status") async def custom_status(): return Response(content="Created", status_code=201) # 返回 201 状态码[^2] ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

micro_cloud_fly

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值