CVE-2025-54121
Description
Starlette is a lightweight ASGI (Asynchronous Server Gateway Interface) framework/toolkit, designed for building async web services in Python. In versions 0.47.1 and below, when parsing a multi-part form with large files (greater than the default max spool size) starlette will block the main thread to roll the file over to disk. This blocks the event thread which means the application can't accept new connections. The UploadFile code has a minor bug where instead of just checking for self._in_memory, the logic should also check if the additional bytes will cause a rollover. The vulnerability is fixed in version 0.47.2.
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Affected packages
Versions sourced from the GitHub Security Advisory.
| Package | Affected versions | Patched versions |
|---|---|---|
starlettePyPI | < 0.47.2 | 0.47.2 |
Affected products
55- osv-coords54 versionspkg:apk/chainguard/airflow-3pkg:apk/chainguard/airflow-3-bitnami-compatpkg:apk/chainguard/airflow-3-compatpkg:apk/chainguard/airflow-3-iamguarded-compatpkg:apk/chainguard/airflow-core-3pkg:apk/chainguard/airflow-core-3-compatpkg:apk/chainguard/airflow-core-3-oci-entrypointpkg:apk/chainguard/k8s-sidecarpkg:apk/chainguard/kservepkg:apk/chainguard/kserve-agentpkg:apk/chainguard/kserve-agent-compatpkg:apk/chainguard/kserve-managerpkg:apk/chainguard/kserve-manager-compatpkg:apk/chainguard/kserve-qpextpkg:apk/chainguard/kserve-qpext-compatpkg:apk/chainguard/kserve-routerpkg:apk/chainguard/kserve-router-compatpkg:apk/chainguard/kserve-storage-controllerpkg:apk/chainguard/mlflowpkg:apk/chainguard/mlflow-bitnamipkg:apk/chainguard/mlflow-iamguarded-compatpkg:apk/chainguard/nemopkg:apk/chainguard/open-webuipkg:apk/chainguard/open-webui-compatpkg:apk/chainguard/py3.10-vllm-cuda-11.8pkg:apk/chainguard/py3.10-wheels-vllm-cuda-11.8pkg:apk/chainguard/reflexpkg:apk/wolfi/airflow-3pkg:apk/wolfi/airflow-3-bitnami-compatpkg:apk/wolfi/airflow-3-compatpkg:apk/wolfi/airflow-3-iamguarded-compatpkg:apk/wolfi/k8s-sidecarpkg:apk/wolfi/kservepkg:apk/wolfi/kserve-agentpkg:apk/wolfi/kserve-agent-compatpkg:apk/wolfi/kserve-managerpkg:apk/wolfi/kserve-manager-compatpkg:apk/wolfi/kserve-qpextpkg:apk/wolfi/kserve-qpext-compatpkg:apk/wolfi/kserve-routerpkg:apk/wolfi/kserve-router-compatpkg:apk/wolfi/kserve-storage-controllerpkg:apk/wolfi/mlflowpkg:apk/wolfi/mlflow-bitnamipkg:apk/wolfi/mlflow-iamguarded-compatpkg:apk/wolfi/open-webuipkg:apk/wolfi/open-webui-compatpkg:apk/wolfi/reflexpkg:pypi/starlettepkg:rpm/opensuse/python-starlette&distro=openSUSE%20Leap%2015.6pkg:rpm/opensuse/python-starlette&distro=openSUSE%20Leap%2016.0pkg:rpm/opensuse/python-starlette&distro=openSUSE%20Tumbleweedpkg:rpm/suse/python-starlette&distro=SUSE%20Linux%20Enterprise%20Server%2016.0pkg:rpm/suse/python-starlette&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20applications%2016.0
< 3.0.3-r3+ 53 more
- (no CPE)range: < 3.0.3-r3
- (no CPE)range: < 3.0.3-r3
- (no CPE)range: < 3.0.3-r3
- (no CPE)range: < 3.0.3-r3
- (no CPE)range: < 3.0.3-r2
- (no CPE)range: < 3.0.3-r2
- (no CPE)range: < 3.0.3-r2
- (no CPE)range: < 1.31.0-r1
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 3.1.4-r0
- (no CPE)range: < 3.1.4-r0
- (no CPE)range: < 3.1.4-r0
- (no CPE)range: < 2.3.2-r3
- (no CPE)range: < 0.6.18-r1
- (no CPE)range: < 0.6.18-r1
- (no CPE)range: < 0.9.2-r2
- (no CPE)range: < 0.9.2-r2
- (no CPE)range: < 0.8.3-r0
- (no CPE)range: < 3.0.3-r3
- (no CPE)range: < 3.0.3-r3
- (no CPE)range: < 3.0.3-r3
- (no CPE)range: < 3.0.3-r3
- (no CPE)range: < 1.31.0-r1
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 0.16.0-r5
- (no CPE)range: < 3.1.4-r0
- (no CPE)range: < 3.1.4-r0
- (no CPE)range: < 3.1.4-r0
- (no CPE)range: < 0.6.18-r1
- (no CPE)range: < 0.6.18-r1
- (no CPE)range: < 0.8.3-r0
- (no CPE)range: < 0.47.2
- (no CPE)range: < 0.35.1-150600.3.6.1
- (no CPE)range: < 0.41.3-160000.3.1
- (no CPE)range: < 0.47.2-1.1
- (no CPE)range: < 0.41.3-160000.3.1
- (no CPE)range: < 0.41.3-160000.3.1
Patches
Vulnerability mechanics
References
5- github.com/advisories/GHSA-2c2j-9gv5-cj73ghsaADVISORY
- nvd.nist.gov/vuln/detail/CVE-2025-54121ghsaADVISORY
- github.com/encode/starlette/blob/fa5355442753f794965ae1af0f87f9fec1b9a3de/starlette/datastructures.pynvdWEB
- github.com/encode/starlette/commit/9f7ec2eb512fcc3fe90b43cb9dd9e1d08696bec1nvdWEB
- github.com/encode/starlette/security/advisories/GHSA-2c2j-9gv5-cj73nvdWEB
News mentions
0No linked articles in our index yet.