CVE-2025-14009: NLTK has a Zip Slip Vulnerability
(updated )
A critical vulnerability exists in the NLTK downloader component of nltk/nltk, affecting all versions. The _unzip_iter function in nltk/downloader.py uses zipfile.extractall() without performing path validation or security checks. This allows attackers to craft malicious zip packages that, when downloaded and extracted by NLTK, can execute arbitrary code. The vulnerability arises because NLTK assumes all downloaded packages are trusted and extracts them without validation. If a malicious package contains Python files, such as init.py, these files are executed automatically upon import, leading to remote code execution. This issue can result in full system compromise, including file system access, network access, and potential persistence mechanisms.
References
- github.com/advisories/GHSA-7p94-766c-hgjp
- github.com/nltk/nltk
- github.com/nltk/nltk/blob/4154eb85e832f266660a09286c7e37e308292284/ChangeLog
- github.com/nltk/nltk/commit/1056b323af6462455571302e766b67cf300aea18
- github.com/nltk/nltk/pull/3468
- huntr.com/bounties/49ecbc02-054e-4470-b2e0-b267936cc4e4
- nvd.nist.gov/vuln/detail/CVE-2025-14009
Code Behaviors & Features
Detect and mitigate CVE-2025-14009 with GitLab Dependency Scanning
Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →