CVE Vulnerabilities

CVE-2024-56337

Time-of-check Time-of-use (TOCTOU) Race Condition

Published: Dec 20, 2024 | Modified: Nov 03, 2025
CVSS 3.x
N/A
Source:
NVD
CVSS 2.x
RedHat/V2
RedHat/V3
8.1 MODERATE
CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H
Ubuntu
MEDIUM
root.io logo minimus.io logo echo.ai logo

Time-of-check Time-of-use (TOCTOU) Race Condition vulnerability in Apache Tomcat.

This issue affects Apache Tomcat: from 11.0.0-M1 through 11.0.1, from 10.1.0-M1 through 10.1.33, from 9.0.0.M1 through 9.0.97. The following versions were EOL at the time the CVE was created but are known to be affected: 8.5.0 though 8.5.100. Other, older, EOL versions may also be affected.

The mitigation for CVE-2024-50379 was incomplete.

Users running Tomcat on a case insensitive file system with the default servlet write enabled (readonly initialisation parameter set to the non-default value of false) may need additional configuration to fully mitigate CVE-2024-50379 depending on which version of Java they are using with Tomcat:

  • running on Java 8 or Java 11: the system property sun.io.useCanonCaches must be explicitly set to false (it defaults to true)
  • running on Java 17: the system property sun.io.useCanonCaches, if set, must be set to false (it defaults to false)
  • running on Java 21 onwards: no further configuration is required (the system property and the problematic cache have been removed)

Tomcat 11.0.3, 10.1.35 and 9.0.99 onwards will include checks that sun.io.useCanonCaches is set appropriately before allowing the default servlet to be write enabled on a case insensitive file system. Tomcat will also set sun.io.useCanonCaches to false by default where it can.

Weakness

The product checks the state of a resource before using that resource, but the resource’s state can change between the check and the use in a way that invalidates the results of the check.

Affected Software

NameVendorStart VersionEnd Version
TomcatApache9.0.0 (including)9.0.98 (excluding)
TomcatApache10.1.0 (including)10.1.34 (excluding)
TomcatApache11.0.0 (including)11.0.2 (excluding)
Red Hat Enterprise Linux 10RedHattomcat9-1:9.0.87-5.el10_0.1*
Red Hat Enterprise Linux 8RedHattomcat-1:9.0.87-1.el8_10.4*
Red Hat Enterprise Linux 8.8 Telecommunications Update ServiceRedHattomcat-1:9.0.87-1.el8_8.5*
Red Hat Enterprise Linux 8.8 Update Services for SAP SolutionsRedHattomcat-1:9.0.87-1.el8_8.5*
Red Hat Enterprise Linux 9RedHattomcat-1:9.0.87-3.el9_6.1*
Red Hat Enterprise Linux 9.2 Update Services for SAP SolutionsRedHattomcat-1:9.0.87-1.el9_2.4*
Red Hat Enterprise Linux 9.4 Extended Update SupportRedHattomcat-1:9.0.87-1.el9_4.4*
Red Hat JBoss Web Server 5RedHattomcat*
Red Hat JBoss Web Server 5.8 on RHEL 7RedHatjws5-tomcat-0:9.0.87-11.redhat_00010.1.el7jws*
Red Hat JBoss Web Server 5.8 on RHEL 8RedHatjws5-tomcat-0:9.0.87-11.redhat_00010.1.el8jws*
Red Hat JBoss Web Server 5.8 on RHEL 9RedHatjws5-tomcat-0:9.0.87-11.redhat_00010.1.el9jws*
Tomcat10Ubuntuesm-apps/noble*
Tomcat10Ubuntunoble*
Tomcat10Ubuntuoracular*
Tomcat10Ubuntuupstream*
Tomcat6Ubuntuupstream*
Tomcat7Ubuntuupstream*
Tomcat8Ubuntuesm-apps/bionic*
Tomcat8Ubuntuesm-infra/xenial*
Tomcat8Ubuntuupstream*
Tomcat9Ubuntuesm-apps/bionic*
Tomcat9Ubuntuesm-apps/focal*
Tomcat9Ubuntuesm-apps/jammy*
Tomcat9Ubuntufocal*
Tomcat9Ubuntujammy*
Tomcat9Ubuntuoracular*
Tomcat9Ubuntuupstream*

Potential Mitigations

References