赞
踩
参考内容:
在很多情况下,在服务端出现错误时,我们需要告诉客户端出现了什么错误,例如:
这时,我们需要返回给客户端400-499范围内的HTTP状态码。接下来介绍如何通过fastapi对服务端错误进行处理并返回给客户端HTTP状态码
如果希望将错误返回给客户端,可以使用HTTPException
:
from fastapi import FastAPI, HTTPException
app = FastAPI()
items = {
"foo": "The Foo Wrestlers"}
@app.get("/items/{item_id}")
async def read_item(item_id: str):
if item_id not in items:
raise HTTPException(status_code=404, detail="Item not found")
return {
"item": items[item_id]}
上面这个代码的含义是希望当查询的item_id不存在时,返回404状态码,并告诉客户端查询的id不存在。
我们先尝试请求http://127.0.0.1:8000/items/a
,看看服务端会响应什么:
回到代码中,我们注意到这里的HTTPException
使用了raise
,而不是return
,这是为什么呢?
因为HTTPException
本身是python的异常类,异常我们通常都是需要将它抛出,所以用了raise
。这也就意味着,当我们触发了HTTPException
这个异常,余下的代码将不会再执行,并且服务端会直接将错误通过HTTPException
响应给客户端。
另外,当我们抛出HTTPException
时,服务端会返回给我们:
{
"detail": "Item not found"
}
如果我们想返回更具体的错误信息,可以对detail
进行修改,它不仅可以接收字符串,也可以是json、dict、list等结构,例如我们修改代码:
from fastapi import FastAPI, HTTPException
app = FastAPI()
items = {
"foo": "The Foo Wrestlers"}
@app.get("/items/{item_id}")
async def read_item(item_id: str):
if item_id not in items:
raise HTTPException(status_code=404, detail={
'msg': "Item not found"})
return {
"item": items[item_id]}
再次请求http://127.0.0.1:8000/items/a
,此时的响应就发生了变化:
{
"detail&
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。