FastAPIでOpenAPI仕様を使用してAPIインターフェースを定義する方法
OpenAPI 仕様を使用して FastAPI で API インターフェイスを定義する方法
はじめに:
Web API を作成する場合、適切な API ドキュメントは非常に重要です。開発者が API をすぐに理解して使用できるように、明確なドキュメントとインターフェイス定義を提供できます。 OpenAPI 仕様は、標準ベースの方法で API ドキュメントを定義および生成できる強力な機能とエコシステム サポートを備えたユニバーサル API 記述言語です。 FastAPI は、OpenAPI 仕様を完全に統合し、強力な自動ドキュメント生成および検証機能を提供する最新の Python Web フレームワークです。この記事では、OpenAPI 仕様を使用して FastAPI で API インターフェイスを定義する方法を紹介し、対応するコード例を示します。
1. FastAPI と pydantic ライブラリをインストールする
始める前に、FastAPI と pydantic ライブラリをインストールする必要があります。これらは次のコマンドでインストールできます:
pip install fastapi pip install uvicorn[standard] pip install pydantic
2. 単純な API インターフェイスの作成
最初に、OpenAPI 仕様の使用方法を示すための単純な API インターフェイスを作成します。 main.py
という名前のファイルに、次のコードを記述します。
from fastapi import FastAPI app = FastAPI() @app.get("/hello") def hello(): return {"message": "Hello, World!"}
このコードは、/hello
の GET リクエスト インターフェイスを作成し、# を含む JSON レスポンスを返します。 ##メッセージフィールド。次に、アプリケーションを実行する必要があります。次のコマンドで実行できます:
uvicorn main:app --reload
アプリケーションの実行後、ブラウザで
http://localhost:8000/docs を開くことができます。自動生成された API ドキュメントにアクセスします。このページは、OpenAPI 仕様に基づいて FastAPI によって自動生成されたドキュメントです。パス、リクエスト メソッド、リクエスト パラメータ、レスポンスの例など、
/hello インターフェイスの詳細を確認できます。さらに、ドキュメント ページでこのインターフェイスをテストすることもできます。
実際のアプリケーションでは、通常、ユーザー入力を受け取るためにパラメーターを使用する必要があります。 FastAPI は、パス パラメーター、クエリ パラメーター、リクエスト本文パラメーター、リクエスト ヘッダー パラメーターなどのパラメーターを定義する複数の方法を提供します。以下では、これらのパラメーターの使用方法を説明します。
パス パラメータは URL の一部であり、動的変数を受け取るために使用されます。
{} を通じてパス パラメータを定義できます。以下の例では、ユーザー ID をパス パラメーターとして受け入れるインターフェイスを作成します。
from fastapi import FastAPI app = FastAPI() @app.get("/users/{user_id}") def get_user(user_id: int): return {"user_id": user_id}
http://localhost:8000/users/1 にアクセスすると、JSON 応答
{"user_id": 1 が返されます。 }。
クエリ パラメータは URL の一部であり、ユーザーから渡されたキーと値のペアを受け取るために使用されます。 FastAPI では、関数パラメータのデフォルト値を通じてクエリ パラメータを定義できます。以下の例では、
limit および
offset クエリ パラメーターを受け入れるインターフェイスを作成します。
from fastapi import FastAPI app = FastAPI() @app.get("/users/") def get_users(limit: int = 10, offset: int = 0): return {"limit": limit, "offset": offset}
http://localhost:8000/users/?limit=20&offset=10 にアクセスすると、JSON 応答が得られます
{ 「制限」: 20、「オフセット」: 10}。
リクエスト本文パラメータは、HTTP リクエスト本文を通じて渡されるデータであり、通常はより大きなデータを受信するために使用されます。 FastAPI では、
pydantic ライブラリのモデルを通じてリクエスト本文のパラメーターを定義できます。次の例では、ユーザー情報をリクエスト本文パラメーターとして受け入れるインターフェイスを作成します。
from fastapi import FastAPI from pydantic import BaseModel app = FastAPI() class User(BaseModel): name: str age: int @app.post("/users/") def create_user(user: User): return {"user": user}
curl などのツールを使用して POST リクエストを送信します。
curl -X POST -H "Content-Type: application/json" -d '{"name":"Alice", "age": 25}' http://localhost:8000/users/
{"user" : {"名前": "アリス"、"年齢": 25}}。
リクエスト ヘッダー パラメーターは、HTTP リクエスト ヘッダーを通じて渡されるパラメーターであり、通常、セキュリティ検証情報を渡すために使用されます。 FastAPI では、関数パラメータの
Header() メソッドを使用してリクエスト ヘッダー パラメータを定義できます。以下の例では、
api_key リクエスト ヘッダー パラメーターを受け入れるインターフェイスを作成します。
from fastapi import FastAPI, Header app = FastAPI() @app.get("/protected/") def protected(api_key: str = Header(...)): return {"api_key": api_key}
http://localhost:8000/protected/ にアクセスし、カスタム
api_key リクエスト ヘッダーを指定すると、次の情報を取得できます。 JSON レスポンス
{"api_key": 。
この記事では、OpenAPI 仕様を使用して FastAPI で API インターフェイスを定義する方法を紹介します。 FastAPI が提供するデコレータとパラメータ型アノテーションを使用することで、API インターフェイスを簡単に定義および検証できます。自動的に生成される OpenAPI ドキュメントを通じて、API インターフェイスをすぐに理解して使用でき、他の開発者と簡単に共同作業したり通信したりできます。この記事が、FastAPI での API インターフェイスのより適切な定義と使用に役立つことを願っています。
以上がFastAPIでOpenAPI仕様を使用してAPIインターフェースを定義する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











リバース プロキシとロード バランシングのために FastAPI で Nginx を使用する方法 はじめに: FastAPI と Nginx は 2 つの非常に人気のある Web 開発ツールです。 FastAPI は高性能 Python フレームワークであり、Nginx は強力なリバース プロキシ サーバーです。これら 2 つのツールを一緒に使用すると、Web アプリケーションのパフォーマンスと信頼性が向上します。この記事では、リバース プロキシと負荷分散のために FastAPI で Nginx を使用する方法を学びます。逆生成とは何ですか

FastAPI でリクエストの高い同時実行性と負荷分散を実現する方法 はじめに: インターネットの発展に伴い、Web アプリケーションの高い同時性が一般的な問題になりました。大量のリクエストを処理するときは、効率的なフレームワークとテクノロジーを使用して、システムのパフォーマンスとスケーラビリティを確保する必要があります。 FastAPI は、高い同時実行性と負荷分散の実現に役立つ高性能 Python フレームワークです。この記事では、FastAPI を使用してリクエストの高い同時実行性と負荷分散を実現する方法を紹介します。 Python3.7を使用します

FastAPI でプッシュ通知を使用してリアルタイムでデータを更新する方法 はじめに: インターネットの継続的な発展に伴い、リアルタイムのデータ更新の重要性がますます高まっています。たとえば、リアルタイム取引、リアルタイム監視、リアルタイム ゲームなどのアプリケーション シナリオでは、最も正確な情報と最高のユーザー エクスペリエンスを提供するために、データをタイムリーに更新する必要があります。 FastAPI は、高パフォーマンスの Web アプリケーションを構築するためのシンプルかつ効率的な方法を提供する、最新の Python ベースの Web フレームワークです。この記事では、FastAPIを使用して実装する方法を紹介します。

FastAPI でリクエストのセキュリティ保護と脆弱性修復を実装する方法 はじめに: Web アプリケーションの開発プロセスでは、アプリケーションのセキュリティを確保することが非常に重要です。 FastAPI は、高速 (高性能) で使いやすい、ドキュメントの自動生成機能を備えた Python Web フレームワークです。この記事では、FastAPI でリクエストのセキュリティ保護と脆弱性修復を実装する方法を紹介します。 1. 安全な HTTP プロトコルを使用する HTTPS プロトコルの使用は、アプリケーション通信のセキュリティを確保するための基礎です。 FastAPI が提供する

FastAPI でファイルのアップロードと処理を実装する方法 FastAPI は、使いやすく強力な最新の高パフォーマンス Web フレームワークで、ファイルのアップロードと処理のネイティブ サポートを提供します。この記事では、FastAPI フレームワークでファイルのアップロードおよび処理関数を実装する方法を学び、具体的な実装手順を示すコード例を示します。まず、必要なライブラリとモジュールをインポートする必要があります: fromfastapiimportFastAPI,UploadF

FastAPI でリクエスト失敗の回復と再試行を実装する方法 はじめに: Web アプリケーションの開発では、多くの場合、他のサービスと通信する必要があります。ただし、これらのサービスでは、一時的なネットワークの停止や応答のタイムアウトなどの障害が発生する可能性があります。アプリケーションの信頼性を維持するには、障害から回復し、必要に応じて再試行する必要があります。この記事では、FastAPI でフェイルオーバーとリクエストの再試行を実装する方法を学びます。 FastAPI は Python をベースにした最新の Web アプリケーションです

FastAPI で負荷分散と高可用性を実装する方法の紹介: インターネット アプリケーションの開発に伴い、システムの負荷分散と高可用性の要件がますます高くなっています。 FastAPI は、Web アプリケーションを構築、デプロイ、拡張するためのシンプルかつ強力な方法を提供する、高性能の Python ベースの Web フレームワークです。この記事では、FastAPI で負荷分散と高可用性を実装する方法を紹介し、対応するコード例を示します。 Nginx を使用して負荷分散を実現するNginx は人気のある

FastAPI でキャッシュを使用して応答を高速化する方法 はじめに: 最新の Web 開発では、パフォーマンスが重要な関心事です。アプリケーションが顧客のリクエストに迅速に対応できない場合、ユーザー エクスペリエンスの低下やユーザーの離脱につながる可能性があります。キャッシュの使用は、Web アプリケーションのパフォーマンスを向上させる一般的な方法の 1 つです。この記事では、キャッシュを使用して FastAPI フレームワークの応答速度を高速化する方法を検討し、対応するコード例を示します。 1. キャッシュとは何ですか?キャッシュとは頻繁にアクセスされるキャッシュのことです
