← volver
CVE-2024-36401

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

CVSS 9.8 CRITICALEPSS 99.8%● KEVCWE-95
En resumen

GeoServer permite que atacantes no autenticados ejecuten código arbitrario enviando solicitudes especialmente diseñadas con nombres de propiedades maliciosos. Esto afecta a todas las instalaciones predeterminadas de GeoServer y puede explotarse a través de varios tipos de solicitud sin requerir autenticación.

Detalle técnico

CWE-95: Neutralización Inadecuada de Directivas en Código Evaluado Dinámicamente. La vulnerabilidad existe en la evaluación insegura de nombres de propiedades/atributos como expresiones XPath mediante la biblioteca commons-jxpath, aplicada incorrectamente a tipos de característica simples. Vector de ataque: red, no autenticado, requiriendo solo solicitudes OGC diseñadas (WFS GetFeature, WFS GetPropertyValue, WMS GetMap, WMS GetFeatureInfo, WMS GetLegendGraphic, WPS Execute) para lograr ejecución remota de código con privilegios del sistema.

Resumen generado y traducido por IA a partir de la descripción oficial.
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.
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
Productos afectados
geoserver · geoserver
⚠ Recursos públicos, para evaluar la exposición de sistemas que controlas o estás autorizado a probar. Prueba solo con autorización.

¿Quieres saber si tu infraestructura está expuesta a esto?

Hablar con TrueHacking →