>백엔드 개발 >파이썬 튜토리얼 >내 React UI가 FastAPI 백엔드의 POST 응답을 표시하지 않는 이유는 무엇입니까?

내 React UI가 FastAPI 백엔드의 POST 응답을 표시하지 않는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-08 16:45:02444검색

Why is My React UI Not Displaying POST Response from a FastAPI Backend?

React UI가 FastAPI 백엔드의 POST 응답을 표시하지 않음

이 시나리오에서 React UI는 FastAPI에서 JSON 파일을 가져올 것으로 예상됩니다. 백엔드는 "localhost:8000/todo"에 있고 데이터는 "localhost:3000"에 UI의 일부로 표시됩니다. 그러나 JSON 파일의 두 항목("책을 읽으세요." 및 "시내를 순환하세요.")이 표시되지 않습니다.

문제 근본 원인:

문제는 FastAPI 백엔드에 CORS(Cross-Origin Resource Sharing) 구성이 부족하다는 것입니다. CORS는 한 출처의 리소스를 다른 출처의 리소스와 공유할 수 있게 해주는 메커니즘입니다. 이 경우 React UI와 FastAPI 백엔드가 서로 다른 도메인에서 실행되기 때문에 필요합니다.

해결책:

FastAPI 백엔드에서 CORS를 활성화하려면 CORSMiddleware를 구성해야 합니다. 이 미들웨어를 사용하면 백엔드 액세스가 허용되는 원본, 허용되는 메서드 및 헤더, 자격 증명 허용 여부를 지정할 수 있습니다.

구현 예:

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://localhost:3000"이라는 두 원본의 요청을 허용하도록 구성되었습니다. "http://127.0.0.1:3000." 또한 모든 메소드와 헤더를 허용하고 자격 증명 공유를 활성화합니다.

참고:

원본은 프로토콜, 도메인 및 포트의 조합을 참조한다는 점을 기억하는 것이 중요합니다. . 따라서 포트가 다른 localhost URL이라도 원본이 다른 것으로 간주되므로 CORS 구성이 필요합니다.

위 내용은 내 React UI가 FastAPI 백엔드의 POST 응답을 표시하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.