VDB
KO
MEDIUM 5.3

PYSEC-2026-248

Details

Starlette is a lightweight ASGI framework/toolkit. Prior to 1.3.0, the HTTP request path is not validated before being used to reconstruct request.url. Because request.url is rebuilt by concatenating {scheme}://{host}{path} and re-parsing the result, a path that does not begin with / (for example @google.com) moves the authority boundary during re-parsing, so request.url.hostname and request.url.netloc become attacker-controlled. Code that reads request.url.hostname (rather than the Host header or scope) can therefore be misled into trusting an attacker-supplied host. This vulnerability is fixed in 1.3.0.

Are you affected?

Enter the version of the package you're using.

Affected packages

PyPI / starlette
Introduced in: 0 Fixed in: 1.3.0
Fix pip install --upgrade 'starlette>=1.3.0'

References