W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
您可能之前閱讀過,您可以設(shè)置默認(rèn)的Response Status Code。
但在某些情況下,您需要返回與默認(rèn)值不同的狀態(tài)代碼。
例如,假設(shè)您希望200默認(rèn)返回“OK”的 HTTP 狀態(tài)代碼。
但是如果數(shù)據(jù)不存在,你想創(chuàng)建它,并返回一個 HTTP 狀態(tài)代碼 "CREATED" 201。
但是您仍然希望能夠過濾和轉(zhuǎn)換您使用response_model.
對于這些情況,您可以使用Response參數(shù)。
您可以Response在路徑操作函數(shù)中聲明一個 type 參數(shù)(就像對 cookie 和 headers 所做的那樣)。
然后您可以status_code在該時間響應(yīng)對象中設(shè)置 。
from fastapi import FastAPI, Response, status
app = FastAPI()
tasks = {"foo": "Listen to the Bar Fighters"}
@app.put("/get-or-create-task/{task_id}", status_code=200)
def get_or_create_task(task_id: str, response: Response):
if task_id not in tasks:
tasks[task_id] = "This didn't exist before"
response.status_code = status.HTTP_201_CREATED
return tasks[task_id]
然后您可以像往常一樣返回您需要的任何對象(a dict、數(shù)據(jù)庫模型等)。
如果您聲明了 a response_model,它仍將用于過濾和轉(zhuǎn)換您返回的對象。
FastAPI將使用該臨時響應(yīng)來提取狀態(tài)代碼(還有 cookie 和標(biāo)頭),并將它們放入包含您返回的值的最終響應(yīng)中,由 any 過濾response_model。
您也可以Response在依賴項中聲明參數(shù),并在其中設(shè)置狀態(tài)碼。但請記住,最后一個設(shè)置將獲勝。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: