目次
React アプリケーションで FastAPI バックエンドからの JSON データが表示されない
問題
原因
解決策
説明
追加情報
ホームページ バックエンド開発 Python チュートリアル React アプリが FastAPI バックエンドからの JSON データを表示しないのはなぜですか?

React アプリが FastAPI バックエンドからの JSON データを表示しないのはなぜですか?

Nov 10, 2024 am 04:16 AM

Why Isn't My React App Displaying JSON Data from My FastAPI Backend?

React アプリケーションで FastAPI バックエンドからの JSON データが表示されない

問題

React アプリケーションがローカルホストの FastAPI バックエンドから取得した JSON データの表示に失敗します。 8000/todo。データは受信されますが、React UI でレンダリングされません。

原因

この問題は、FastAPI バックエンドの Cross-Origin Resource Sharing (CORS) 構成の欠如によって発生します。デフォルトでは、ブラウザはセキュリティ リスクを防ぐためにクロスオリジン リクエストを制限します。

解決策

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

次のコードは、FastAPI アプリケーションで CORS を有効にする方法を示しています。

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

app = FastAPI()

origins = ["http://localhost:3000", "http://127.0.0.1:3000"]

app.add_middleware(
    CORSMiddleware,
    allow_origins=origins,
    allow_credentials=True,
    allow_methods=["*"],
    allow_headers=["*"],
)
ログイン後にコピー

説明

CORSMiddleware は、指定されたオリジン (この例では http://localhost:3000 および http://127.0.0.1:3000) からのクロスオリジン リクエストを許可します。また、リクエストに Cookie を含めることも許可され (allow_credentials=True)、HTTP メソッドまたはヘッダーは制限されません (allow_methods=["*"]、allow_headers=["*"])。

追加情報

  • CORS ヘッダー: CORS ミドルウェアによって設定された HTTP ヘッダーは、ブラウザーがクロスオリジン リクエストを処理する方法を制御します。たとえば、Access-Control-Allow-Origin ヘッダーは、リクエストに許可されるオリジンを指定します。
  • Origin: オリジンとは、リクエストのプロトコル、ドメイン、およびポートを指します。異なるオリジンからのリクエストはクロスオリジン リクエストとみなされます。
  • 同一オリジン ポリシー: デフォルトでは、ブラウザは同一オリジン ポリシーを適用し、セキュリティの脆弱性を防ぐためにクロスオリジン リクエストを制限します。 CORS は、このポリシーを緩和する方法を提供します。

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

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

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

HTMLを解析するために美しいスープを使用するにはどうすればよいですか? HTMLを解析するために美しいスープを使用するにはどうすればよいですか? Mar 10, 2025 pm 06:54 PM

HTMLを解析するために美しいスープを使用するにはどうすればよいですか?

Pythonでの画像フィルタリング Pythonでの画像フィルタリング Mar 03, 2025 am 09:44 AM

Pythonでの画像フィルタリング

Pythonでファイルをダウンロードする方法 Pythonでファイルをダウンロードする方法 Mar 01, 2025 am 10:03 AM

Pythonでファイルをダウンロードする方法

Pythonを使用してテキストファイルのZIPF配布を見つける方法 Pythonを使用してテキストファイルのZIPF配布を見つける方法 Mar 05, 2025 am 09:58 AM

Pythonを使用してテキストファイルのZIPF配布を見つける方法

Pythonを使用してPDFドキュメントの操作方法 Pythonを使用してPDFドキュメントの操作方法 Mar 02, 2025 am 09:54 AM

Pythonを使用してPDFドキュメントの操作方法

DjangoアプリケーションでRedisを使用してキャッシュする方法 DjangoアプリケーションでRedisを使用してキャッシュする方法 Mar 02, 2025 am 10:10 AM

DjangoアプリケーションでRedisを使用してキャッシュする方法

TensorflowまたはPytorchで深い学習を実行する方法は? TensorflowまたはPytorchで深い学習を実行する方法は? Mar 10, 2025 pm 06:52 PM

TensorflowまたはPytorchで深い学習を実行する方法は?

Natural Language Toolkit(NLTK)の紹介 Natural Language Toolkit(NLTK)の紹介 Mar 01, 2025 am 10:05 AM

Natural Language Toolkit(NLTK)の紹介

See all articles