CVE-2026-48710
Starlette has missing Host header validation that poisons request.url.path, bypassing path-based security checks
En resumen
Starlette no validaba adecuadamente el encabezado HTTP Host, permitiendo que atacantes envíen solicitudes malformadas que hagan que la ruta de la URL parezca diferente a la que se solicitó realmente. Esto puede eludir verificaciones de seguridad basadas en la ruta de la URL.
Detalle técnico
La vulnerabilidad existe en versiones de Starlette anteriores a 1.0.1, donde el encabezado Host se usa para reconstruir request.url sin validación según RFC 9112/3986. Un atacante puede enviar un Host malformado para hacer que request.url.path diverja de la ruta de enrutamiento real en scope, permitiendo eludir middleware de seguridad y restricciones de endpoints que verifican request.url en lugar de valores brutos de scope.
Resumen generado y traducido por IA a partir de la descripción oficial.
Starlette is a lightweight ASGI framework/toolkit. Prior to version 1.0.1, the HTTP `Host` request header was not validated before being used to reconstruct `request.url`. Because the routing algorithm relies on the raw HTTP path while `request.url` is rebuilt from the `Host` header, a malformed header could make `request.url.path` differ from the path that was actually requested. Middleware and endpoints that apply security restrictions based on `request.url` (rather than the raw `scope` path) could therefore be bypassed. Users should upgrade to a version greater than or equal to version 1.0.1, which validates the `Host` header against the grammar of RFC 9112 §3.2 / RFC 3986 §3.2.2 when constructing `request.url` and falls back to `scope["server"]` for malformed values.
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N
⚠ Recursos públicos, para evaluar la exposición de sistemas que controlas o estás autorizado a probar. Prueba solo con autorización.