Your RSA-2048 keys break in 2030. Find every one of them before attackers do.
CISA KEV·Added 2024-08-19 — agencies required to remediate by 2024-09-09 · Ransomware
Maven

GHSA-6f9g-cxwr-q5jr

CRITICAL

Arbitrary file read vulnerability through the Jenkins CLI can lead to RCE

Also known asBIT-jenkins-2024-23897CVE-2024-23897
Published
Jan 24, 2024
Updated
Feb 4, 2026
Affected
3 pkgs
Patched
3 / 3
Exploits
40 known

EPSS Exploitation Probability

via FIRST.org ↗
94.5%probability of exploitation in next 30 days
Very High Risk100th percentile0.00%
94.0%94.3%94.6%95.0%94.5%94.5%Dec 25Apr 26Jun 26

EPSS (Exploit Prediction Scoring System) is a daily probability model maintained by FIRST.org. It estimates the likelihood a CVE will be exploited in production environments within the next 30 days, derived from real-world threat intelligence signals.

Blast Radius

3 pkgs affected
org.jenkins-ci.main:jenkins-coreorg.jenkins-ci.main:jenkins-coreorg.jenkins-ci.main:jenkins-core

Real-time download stats are indexed for npm and PyPI packages. This vulnerability affects Maven packages — download data is not available via public APIs for these ecosystems.

Description

Jenkins has a built-in command line interface (CLI) to access Jenkins from a script or shell environment.

Jenkins uses the args4j library to parse command arguments and options on the Jenkins controller when processing CLI commands. This command parser has a feature that replaces an @ character followed by a file path in an argument with the file’s contents (expandAtFiles). This feature is enabled by default and Jenkins 2.441 and earlier, LTS 2.426.2 and earlier does not disable it.

This allows attackers to read arbitrary files on the Jenkins controller file system using the default character encoding of the Jenkins controller process.

  • Attackers with Overall/Read permission can read entire files.

  • Attackers without Overall/Read permission can read the first few lines of files. The number of lines that can be read depends on available CLI commands. As of publication of this advisory, the Jenkins security team has found ways to read the first three lines of files in recent releases of Jenkins without having any plugins installed, and has not identified any plugins that would increase this line count.

Binary files containing cryptographic keys used for various Jenkins features can also be read, with some limitations (see note on binary files below). As of publication, the Jenkins security team has confirmed the following possible attacks in addition to reading contents of all files with a known file path. All of them leverage attackers' ability to obtain cryptographic keys from binary files, and are therefore only applicable to instances where that is feasible.

Affected Packages

3 total 3 fixed
EcosystemPackageVulnerable rangeFix
Mavenorg.jenkins-ci.main:jenkins-core1.606&&< 2.426.32.426.3
Mavenorg.jenkins-ci.main:jenkins-core2.427&&< 2.440.12.440.1
Mavenorg.jenkins-ci.main:jenkins-core2.441&&< 2.4422.442
Exploits & PoCs
40

Research use only. For defensive security, authorized penetration testing, and academic research only. Never execute exploit code against systems without explicit written authorization.

EDB-51993webappsjava

Jenkins 2.441 - Local File Inclusion

by Matisse Beckandt · Apr 15, 2024

Frequently Asked Questions

Jenkins has a built-in command line interface (CLI) to access Jenkins from a script or shell environment. Jenkins uses the args4j library to parse command arguments and options on the Jenkins controller when processing CLI commands. This command parser has a feature that replaces an @ character followed by a file path in an argument with the file’s contents (expandAtFiles). This feature is enabled by default and Jenkins 2.441 and earlier, LTS 2.426.2 and earlier does not disable it. This allows attackers to read arbitrary files on the Jenkins controller file system using the default characte
O3 Security · Impact-Aware SCA

Is GHSA-6f9g-cxwr-q5jr in your stack?

O3 detects GHSA-6f9g-cxwr-q5jr across Maven dependencies and uses function-level reachability to confirm whether the vulnerable code path is actually reachable — not just present. No false positives.