ホームページ >バックエンド開発 >Python チュートリアル >React フロントエンドに FastAPI バックエンドからの POST 応答が表示されないのはなぜですか?

React フロントエンドに FastAPI バックエンドからの POST 応答が表示されないのはなぜですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-11-12 12:17:02660ブラウズ

Why Isn't My React Frontend Displaying POST Response from My FastAPI Backend?

React で FastAPI バックエンドからの POST 応答が表示されない: CORS 問題の解決

React で HTTP から JSON データを取得しようとしています。別のポートで実行されている FastAPI バックエンドへの POST リクエスト。ただし、フロントエンドは期待どおりに応答をレンダリングしません。

CORS について

この理由は、Cross-Origin Resource Sharing (CORS) です。 CORS は、ブラウザーがプロトコル、ドメイン、ポートによって定義された異なる送信元からのリソース (JSON データなど) にリクエストを送信することを制限するセキュリティ メカニズムです。あなたの場合、フロントエンド (localhost:3000) は、異なるオリジンであるバックエンド (localhost:8000) からリソースにアクセスしようとしています。

FastAPI で CORS を有効にする

この問題を解決するには、FastAPI アプリケーションで CORS を有効にする必要があります。これは、次のように構成された CORSMiddleware を使用して実現できます。

from fastapi import FastAPI
from fastapi.middleware.cors import CORSMiddleware

app = FastAPI()
app.add_middleware(
    CORSMiddleware,
    allow_origins=["YOUR_FRONTEND_ORIGIN"],
    allow_credentials=True,
    allow_methods=["*"],  # Allow all HTTP methods
    allow_headers=["*"],  # Allow all HTTP headers
)

「YOUR_FRONTEND_ORIGIN」を React フロントエンドのオリジン (通常は「http://localhost:3000」) に置き換えます。これにより、バックエンドは CORS エラーなしでフロントエンドからの POST リクエストに応答できるようになります。

以上がReact フロントエンドに FastAPI バックエンドからの POST 応答が表示されないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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