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

CVE-2024-36401

CRITICAL

Remote Code Execution (RCE) vulnerability in evaluating property name expressions in Geoserver

Also known asGHSA-6jj6-gm7p-fcvv
Published
Jul 1, 2024
Updated
Apr 10, 2026
Affected
12 pkgs
Patched
12 / 12
Exploits
25 known

EPSS Exploitation Probability

via FIRST.org ↗
94.4%probability of exploitation in next 30 days
Very High Risk100th percentile0.00%
93.9%94.3%94.6%94.9%94.4%94.4%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

12 pkgs affected
org.geoserver.web:gs-web-apporg.geoserver:gs-wfsorg.geoserver:gs-wmsorg.geoserver.web:gs-web-apporg.geoserver:gs-wfsorg.geoserver:gs-wmsorg.geoserver.web:gs-web-apporg.geoserver:gs-wfs+4 more

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

GeoServer is an open source server that allows users to share and edit geospatial data. Prior to versions 2.22.6, 2.23.6, 2.24.4, and 2.25.2, multiple OGC request parameters allow Remote Code Execution (RCE) by unauthenticated users through specially crafted input against a default GeoServer installation due to unsafely evaluating property names as XPath expressions.

The GeoTools library API that GeoServer calls evaluates property/attribute names for feature types in a way that unsafely passes them to the commons-jxpath library which can execute arbitrary code when evaluating XPath expressions. This XPath evaluation is intended to be used only by complex feature types (i.e., Application Schema data stores) but is incorrectly being applied to simple feature types as well which makes this vulnerability apply to ALL GeoServer instances. No public PoC is provided but this vulnerability has been confirmed to be exploitable through WFS GetFeature, WFS GetPropertyValue, WMS GetMap, WMS GetFeatureInfo, WMS GetLegendGraphic and WPS Execute requests. This vulnerability can lead to executing arbitrary code.

Versions 2.22.6, 2.23.6, 2.24.4, and 2.25.2 contain a patch for the issue. A workaround exists by removing the gt-complex-x.y.jar file from the GeoServer where x.y is the GeoTools version (e.g., gt-complex-31.1.jar if running GeoServer 2.25.1). This will remove the vulnerable code from GeoServer but may break some GeoServer functionality or prevent GeoServer from deploying if the gt-complex module is needed.

Affected Packages

12 total 12 fixed
EcosystemPackageVulnerable rangeFix
Mavenorg.geoserver.web:gs-web-app2.24.0&&< 2.24.42.24.4
Mavenorg.geoserver:gs-wfs2.24.0&&< 2.24.42.24.4
Mavenorg.geoserver:gs-wms2.24.0&&< 2.24.42.24.4
Mavenorg.geoserver.web:gs-web-app2.25.0&&< 2.25.22.25.2
Mavenorg.geoserver:gs-wfs2.25.0&&< 2.25.22.25.2
Mavenorg.geoserver:gs-wms2.25.0&&< 2.25.22.25.2
Exploits & PoCs
25

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

Frequently Asked Questions

GeoServer is an open source server that allows users to share and edit geospatial data. Prior to versions 2.22.6, 2.23.6, 2.24.4, and 2.25.2, multiple OGC request parameters allow Remote Code Execution (RCE) by unauthenticated users through specially crafted input against a default GeoServer installation due to unsafely evaluating property names as XPath expressions. The GeoTools library API that GeoServer calls evaluates property/attribute names for feature types in a way that unsafely passes them to the commons-jxpath library which can execute arbitrary code when evaluating XPath expression
O3 Security · Impact-Aware SCA

Is CVE-2024-36401 in your stack?

O3 detects CVE-2024-36401 across Maven dependencies and uses function-level reachability to confirm whether the vulnerable code path is actually reachable — not just present. No false positives.