Werkzeug safe_join() allows Windows special device names
Description
Werkzeug is a comprehensive WSGI web application library. Prior to version 3.1.4, Werkzeug's safe_join function allows path segments with Windows device names. On Windows, there are special device names such as CON, AUX, etc that are implicitly present and readable in every directory. send_from_directory uses safe_join to safely serve files at user-specified paths under a directory. If the application is running on Windows, and the requested path ends with a special device name, the file will be opened successfully, but reading will hang indefinitely. This issue has been patched in version 3.1.4.
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 |
|---|---|---|
werkzeugPyPI | < 3.1.4 | 3.1.4 |
Affected products
66- osv-coords65 versionspkg:apk/chainguard/airflow-2pkg:apk/chainguard/airflow-2-bitnami-compatpkg:apk/chainguard/airflow-2-compatpkg:apk/chainguard/airflow-2-iamguarded-compatpkg: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-2pkg:apk/chainguard/airflow-core-2-compatpkg:apk/chainguard/airflow-core-2-oci-entrypointpkg:apk/chainguard/azure-functions-python-workerpkg:apk/chainguard/emissarypkg:apk/chainguard/emissary-apiextpkg:apk/chainguard/emissary-oci-entrypointpkg:apk/chainguard/kubeflow-jupyter-web-apppkg:apk/chainguard/kubeflow-pipelines-visualization-serverpkg:apk/chainguard/kubeflow-volumes-web-apppkg:apk/chainguard/localstackpkg:apk/chainguard/localstack-compatpkg:apk/chainguard/mlflowpkg:apk/chainguard/mlflow-bitnamipkg:apk/chainguard/mlflow-iamguarded-compatpkg:apk/chainguard/py3.10-ambassadorpkg:apk/chainguard/py3.11-ambassadorpkg:apk/chainguard/py3.11-azure-functions-workerpkg:apk/chainguard/py3.12-ambassadorpkg:apk/chainguard/py3.12-azure-functions-workerpkg:apk/chainguard/py3.13-ambassadorpkg:apk/chainguard/py3.13-azure-functions-workerpkg:apk/chainguard/py3-supported-azure-functions-workerpkg:apk/chainguard/superset-4.1pkg:apk/chainguard/superset-4.1-entrypointpkg:apk/chainguard/superset-4.1-iamguarded-compatpkg:apk/chainguard/superset-5.0pkg:apk/chainguard/superset-5.0-entrypointpkg:apk/chainguard/superset-5.0-iamguarded-compatpkg:apk/chainguard/tensorflow-cpu-jupyterpkg:apk/chainguard/tensorflow-gpu-jupyterpkg:apk/wolfi/airflow-3pkg:apk/wolfi/airflow-3-bitnami-compatpkg:apk/wolfi/airflow-3-compatpkg:apk/wolfi/airflow-3-iamguarded-compatpkg:apk/wolfi/emissarypkg:apk/wolfi/emissary-apiextpkg:apk/wolfi/emissary-oci-entrypointpkg:apk/wolfi/kubeflow-jupyter-web-apppkg:apk/wolfi/kubeflow-pipelines-visualization-serverpkg:apk/wolfi/kubeflow-volumes-web-apppkg:apk/wolfi/mlflowpkg:apk/wolfi/mlflow-bitnamipkg:apk/wolfi/mlflow-iamguarded-compatpkg:apk/wolfi/py3.10-ambassadorpkg:apk/wolfi/py3.11-ambassadorpkg:apk/wolfi/py3.12-ambassadorpkg:apk/wolfi/py3.13-ambassadorpkg:apk/wolfi/superset-4.1pkg:apk/wolfi/superset-4.1-entrypointpkg:apk/wolfi/superset-4.1-iamguarded-compatpkg:apk/wolfi/superset-5.0pkg:apk/wolfi/superset-5.0-entrypointpkg:apk/wolfi/superset-5.0-iamguarded-compatpkg:apk/wolfi/tensorflow-cpu-jupyterpkg:pypi/werkzeugpkg:rpm/opensuse/python-openapi-core&distro=openSUSE%20Tumbleweed
< 0+ 64 more
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 3.1.3-r0
- (no CPE)range: < 3.1.3-r0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 4.41.1-r0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 1.10.0-r7
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 4.11.1-r1
- (no CPE)range: < 4.11.1-r1
- (no CPE)range: < 3.6.0-r1
- (no CPE)range: < 3.6.0-r1
- (no CPE)range: < 3.6.0-r1
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 4.41.1-r0
- (no CPE)range: < 0
- (no CPE)range: < 4.41.1-r0
- (no CPE)range: < 0
- (no CPE)range: < 4.41.1-r0
- (no CPE)range: < 4.41.1-r0
- (no CPE)range: < 4.1.4-r3
- (no CPE)range: < 4.1.4-r3
- (no CPE)range: < 4.1.4-r3
- (no CPE)range: < 5.0.0-r8
- (no CPE)range: < 5.0.0-r8
- (no CPE)range: < 5.0.0-r8
- (no CPE)range: < 2.20.0-r5
- (no CPE)range: < 2.20.0-r4
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 3.1.3-r0
- (no CPE)range: < 3.1.3-r0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 1.10.0-r7
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 3.6.0-r1
- (no CPE)range: < 3.6.0-r1
- (no CPE)range: < 3.6.0-r1
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 0
- (no CPE)range: < 4.1.4-r3
- (no CPE)range: < 4.1.4-r3
- (no CPE)range: < 4.1.4-r3
- (no CPE)range: < 5.0.0-r8
- (no CPE)range: < 5.0.0-r8
- (no CPE)range: < 5.0.0-r8
- (no CPE)range: < 2.20.0-r5
- (no CPE)range: < 3.1.4
- (no CPE)range: < 0.22.0-1.1
Patches
Vulnerability mechanics
References
5- github.com/advisories/GHSA-hgf8-39gv-g3f2ghsaADVISORY
- nvd.nist.gov/vuln/detail/CVE-2025-66221ghsaADVISORY
- github.com/pallets/werkzeug/commit/4b833376a45c323a189cd11d2362bcffdb1c0c13ghsax_refsource_MISCWEB
- github.com/pallets/werkzeug/releases/tag/3.1.4ghsax_refsource_MISCWEB
- github.com/pallets/werkzeug/security/advisories/GHSA-hgf8-39gv-g3f2ghsax_refsource_CONFIRMWEB
News mentions
0No linked articles in our index yet.