"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > ¿Por qué Fastapi Backend no envía galletas para reaccionar Frontend?

¿Por qué Fastapi Backend no envía galletas para reaccionar Frontend?

Publicado el 2025-05-01
Navegar:907

Why Doesn't My FastAPI Backend Send Cookies to My React Frontend?

fastapi no puede enviar cookies para reaccionar frontend

desbordamiento

fastapi es un marco de Python popular para crear API. Sin embargo, algunos usuarios han informado de problemas con FastAPI que no devuelven cookies para reaccionar aplicaciones frontend.

problema

¿por qué Fastapi no devuelve cookies para reaccionar aplicaciones? Problema:

@router.post ("/login") def user_login (respuesta: respuesta, nombre de usuario: str = form (), contraseña: str = form (), db: session = depends (get_db)) -> dict: # Operaciones de base de datos omitidas para brevedad access_token = create_access_token (data = {"sub": user.mobile_number}) Response.set_cookie (Key = "Fakesession", Value = "Fake-Cookie-Session-Value") return {"status": "éxito"}

Al enviar una solicitud de inicio de sesión de Swagger UI, la cookie aparece en los encabezados de respuesta. Sin embargo, de una aplicación React, no se devuelve ninguna cookie.

@router.post("/login")
def user_login(response: Response, username: str = Form(), password: str = Form(), db: Session = Depends(get_db)) -> dict:
    # Database operations omitted for brevity
    access_token = create_access_token(data={"sub": user.mobile_number})
    response.set_cookie(key="fakesession", value="fake-cookie-session-value")
    return {"status": "success"}

Hay dos pasos para resolver este problema:

Establecer cookies correctamente:
  1. Asegúrese Recibido.

    Establezca la cookie correctamente usando Response.set_cookie (...).

    • Configure Cors y Credentials:
  2. Permitir las solicitudes de Cors mediante la configuración Corsmiddleware.
  3. en la aplicación React, establece WithCredentials: verdadero en las solicitudes de Axios para enviar cookies.

    • explicación
    • &] Cookie Configuración:

verifique que la cookie se establezca correctamente en la respuesta FastAPI. Asegúrese de que se establezcan la clave correcta, el valor, el httponly y otros parámetros relevantes.

  1. Cross-Origin recursos compartiendo (cors):

      ya que la reactación y los rápidos están en los puertos diferentes, se hacen las requisitos cors. Permitir cookies con CORS, el servidor debe permitir orígenes específicos a través de Access-Control-Alow-Origin Response Headers.
    • en Fastapi, use corsmiddleware con tamped_credentials = true.
  2. credenciales en Solicitud:

    • en react, establecer WithCredentials: true en las solicitudes de axios.
    • esto informa al navegador a enviar cookies en las solicitudes posteriores al servidor fastapi.
    • [&]
Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3