ホームページ バックエンド開発 Python チュートリアル FastAPIでOpenAPI仕様を使用してAPIインターフェースを定義する方法

FastAPIでOpenAPI仕様を使用してAPIインターフェースを定義する方法

Jul 28, 2023 pm 12:09 PM
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
ログイン後にコピー

3. OpenAPI ドキュメントの生成

アプリケーションの実行後、ブラウザで
http://localhost:8000/docs を開くことができます。自動生成された API ドキュメントにアクセスします。このページは、OpenAPI 仕様に基づいて FastAPI によって自動生成されたドキュメントです。パス、リクエスト メソッド、リクエスト パラメータ、レスポンスの例など、/hello インターフェイスの詳細を確認できます。さらに、ドキュメント ページでこのインターフェイスをテストすることもできます。

4. パラメーター定義を使用する

実際のアプリケーションでは、通常、ユーザー入力を受け取るためにパラメーターを使用する必要があります。 FastAPI は、パス パラメーター、クエリ パラメーター、リクエスト本文パラメーター、リクエスト ヘッダー パラメーターなどのパラメーターを定義する複数の方法を提供します。以下では、これらのパラメーターの使用方法を説明します。

4.1 パス パラメータ

パス パラメータは 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 が返されます。 }

4.2 クエリ パラメータ

クエリ パラメータは 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}

4.3 リクエスト本文パラメータ

リクエスト本文パラメータは、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/
ログイン後にコピー

JSON 応答を取得します

{"user" : {"名前": "アリス"、"年齢": 25}}

4.4 リクエスト ヘッダー パラメーター

リクエスト ヘッダー パラメーターは、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 サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

リバース プロキシとロード バランシングのために FastAPI で Nginx を使用する方法 リバース プロキシとロード バランシングのために FastAPI で Nginx を使用する方法 Aug 01, 2023 am 09:44 AM

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

FastAPI でリクエストの高い同時実行性と負荷分散を実現する方法 FastAPI でリクエストの高い同時実行性と負荷分散を実現する方法 Jul 31, 2023 pm 01:50 PM

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

FastAPI でプッシュ通知を使用してリアルタイムでデータを更新する方法 FastAPI でプッシュ通知を使用してリアルタイムでデータを更新する方法 Jul 29, 2023 pm 06:09 PM

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

FastAPI でリクエストのセキュリティ保護と脆弱性修復を実装する方法 FastAPI でリクエストのセキュリティ保護と脆弱性修復を実装する方法 Jul 29, 2023 am 10:21 AM

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

FastAPI でファイルのアップロードと処理を実装する方法 FastAPI でファイルのアップロードと処理を実装する方法 Jul 28, 2023 pm 03:01 PM

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

FastAPI でフェイルオーバーとリクエストの再試行を実装する方法 FastAPI でフェイルオーバーとリクエストの再試行を実装する方法 Jul 28, 2023 pm 01:33 PM

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

FastAPI で負荷分散と高可用性を実装する方法 FastAPI で負荷分散と高可用性を実装する方法 Jul 28, 2023 pm 02:13 PM

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

FastAPI でキャッシュを使用して応答を高速化する方法 FastAPI でキャッシュを使用して応答を高速化する方法 Jul 28, 2023 pm 08:17 PM

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

See all articles