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 サイトの他の関連記事を参照してください。