¿Cómo funciona Access-Control-Allow-Credentials?
Access-Control-Allow-Credentials
es una parte específica del protocolo CORS que discutimos. Funciona como un permiso adicional que los servidores otorgan para habilitar un tipo de solicitud de origen cruzado más seguro y confiable.
Para entenderlo, volvamos a la analogía de la casa. .
El Pase VIP con Credenciales
Imagina que tu sitio web (mi-tienda.com
) necesita hacer una solicitud a la API de un servicio de fotos (api-fotos.com
) para obtener las fotos de un usuario. Para que la API sepa de qué usuario se trata, necesita una credencial, como una cookie de sesión o un token de autenticación que el navegador tiene guardado.
Petición normal con CORS: Tu navegador le pide a
api-fotos.com
permiso para acceder a los datos. La API responde conAccess-Control-Allow-Origin: mi-tienda.com
, y la petición funciona. Pero, ¿qué pasa con la cookie?Petición con credenciales: Por defecto, los navegadores no envían cookies ni tokens de autenticación en las solicitudes de origen cruzado. Este es un mecanismo de seguridad para evitar que un sitio malicioso use tu sesión sin tu permiso.
Para que el navegador envíe esas credenciales, tanto la petición como la respuesta deben cumplir con dos condiciones:
En la petición del navegador: Tu código debe enviar la solicitud con la propiedad
credentials
eninclude
. Esto le dice al navegador: "Por favor, envía mis credenciales con esta solicitud".En la respuesta del servidor: El servidor de la API debe incluir la cabecera
Access-Control-Allow-Credentials
con el valortrue
.
Cómo funciona el flujo
El proceso es un poco más complejo que una solicitud CORS simple:
Tu código en
mi-tienda.com
envía una petición al servidor de la API (api-fotos.com
) para obtener tus fotos. La petición incluye la configuración de credenciales.La API recibe la petición y, si confía en tu dominio, responde con dos cabeceras:
Access-Control-Allow-Origin: mi-tienda.com
Access-Control-Allow-Credentials: true
Tu navegador revisa la respuesta. Si ambas cabeceras son correctas, permite que la petición se complete y que el navegador envíe la información de la cookie con la siguiente solicitud.
Punto clave
Access-Control-Allow-Credentials
solo funciona si el valor de Access-Control-Allow-Origin
no es *
(un comodín). Si el servidor de la API permite el acceso desde cualquier origen (*
), no permitirá que se envíen credenciales. Esto es una medida de seguridad extra para evitar el robo de sesiones.
En resumen, Access-Control-Allow-Credentials
es la "llave" que le da al navegador el permiso de enviar información de autenticación junto con una solicitud de origen cruzado. Es una capa de seguridad crucial que permite a las aplicaciones usar sesiones de usuario de forma segura en APIs de terceros.
No hay comentarios:
Publicar un comentario