【FastAPI】カスタムレスポンスの追加やドキュメントの記述
当ページのリンクには広告が含まれています。
data:image/s3,"s3://crabby-images/76253/762537b0bcca63e2adeb19620b4e785c7fbf900c" alt=""
FastAPI
は、基本的にFastAPI
側でよしなに変換してJSON
形式で返してくれますが、別のレスポンスが必要な場合があります。例えば
- テキスト
- リスト
- html・xml
- ファイル
等が挙げられます。
今回はカスタムレスポンスの使い方をご紹介いたします。
FastAPIの基礎についての記事まとめ
目次
カスタムレスポンス
カスタムレスポンスを使用する場合にはfastapi.responses
のResponse
をインポートします。
また、Response
にはサブクラスが用意されており、専用のPlainTextResponse
やHTMLResponse
がなどがあります。
あわせて読みたい
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/c5db6/c5db60969db356d21b45a6f42175c2e6a06837a5" alt=""
レスポンスを直接返す – FastAPI
FastAPI framework, high performance, easy to learn, fast to code, ready for production
あわせて読みたい
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/bfd3b/bfd3b144070a836d8ecdbd1cbb889cec7e366958" alt=""
カスタムレスポンス – HTML、ストリーム、ファイル、その他のレスポンス – FastAPI
FastAPI framework, high performance, easy to learn, fast to code, ready for production
Response
from fastapi import APIRouter
from fastapi.responses import Response
router = APIRouter(
prefix='/products',
tags=['products']
)
products = ['water', 'cola', 'coffee']
@router.get('/all')
def get_products_all():
text_data = " ".join(products)
return Response(content=text_data, media_type='text/plain')
products
でデータとしてリストを作成しました。
Response(content=text_data, media_type='text/plain')
content
で返すデータを、media_type
で型指定しています。
data:image/s3,"s3://crabby-images/03dd7/03dd7c96f9d38d3ca1618e331e72d704255afc6e" alt=""
ステータスコードの付与
ステータスコードの付与も簡単で、status_code
を記入するだけです。
from fastapi import status
~~~
Response(content=text_data, media_type='text/plain', status_code=status.HTTP_200_OK)
関連記事
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/b931b/b931b9ffd625381443127462389418d2cc5644d3" alt=""
【FastAPI】任意のhttpステータスコードを付与する【入門】
代表的なステータスコードには 成功(Success)の200未検出(Not Found)の404サーバーエラー(Internal Server Error)の500 等がありますが、レスポンスがどのような状態な…
HTMLResponse
HTML
も可能です。
関連記事
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/26023/260233e241258937134ff0a1e2eccffcc5b94638" alt=""
【FastAPI】テンプレートエンジンを使ってHTML・CSSを配信
FastAPIを使用してJSONではなく、テンプレートエンジンを用いてHTMLやCSSを返す方法をご紹介いたします。 この記事のサンプルコード テンプレートエンジン テンプレート…
from fastapi.responses import HTMLResponse
@router. get('/{id}')
def get_product(id: int):
product = products[id]
html = f"""
<html>
<h2>product is {id}</h2>
</html>
"""
return HTMLResponse(content=html, media_type="text/html", status_code=status.HTTP_200_OK)
また、response_class
にHTMLResponse
を指定することも可能です。
@router. get('/{id}', response_class=HTMLResponse)
def get_product(id: int):
product = products[id]
html = f"""
<html>
<h2>product is {id}</h2>
</html>
"""
return html
data:image/s3,"s3://crabby-images/559f4/559f4518c313dde05e18ca9008a725997e105636" alt=""
その他にもPlainTextResponse
やXmlResponse
などがあります。
ドキュメントへの記述
レスポンスを作成することは出来ましたが、このままだとドキュメントには何も記載が無く、レスポンス例もstring
しか記載されていません。
レスポンスに関しての記述を追加してみましょう。
あわせて読みたい
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/9faa4/9faa45bc700f7eaab6646b678baa9a1900b5ed84" alt=""
Additional Responses in OpenAPI – FastAPI
FastAPI framework, high performance, easy to learn, fast to code, ready for production
@router.get('/{id}', responses={
200: {
"content": {
"text/html": {
"example": "<div>product is id</div>"
}
},
"description": "return html object"
}
})
def get_product(id: int):
product = products[id]
html = f"""
<html>
<h2>product is {id}</h2>
</html>
"""
return HTMLResponse(content=html, media_type="text/html", status_code=status.HTTP_200_OK)
responses
引数を追加し、status_code
・media_type
・例や説明を追加できます。
これらはステータスコード毎に記述可能です。
関連記事
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/91f9f/91f9f3d096f88b372119d9dda0f73e5494e83f87" alt=""
【FastAPI】APIドキュメントに説明を追加する【入門】
FastAPIにはとても便利な自動生成されるAPIドキュメントがあります。 このドキュメントはタグで分類したり、任意の説明文章を追加することが簡単にできますのでご紹介い…
data:image/s3,"s3://crabby-images/096c8/096c80cae63a9a388417c8fa1f632c35ee80e99d" alt=""
description
media_type
example value
等が変化しています。控え目に言って最強ですね。
FastAPIの基礎についての記事まとめ
コメント