First published: Sun Jun 09 2024(Updated: )
The openssl_private_decrypt function in PHP, when using PKCS1 padding (OPENSSL_PKCS1_PADDING, which is the default), is vulnerable to the Marvin Attack unless it is used with an OpenSSL version that includes the changes from this pull request: https://github.com/openssl/openssl/pull/13817 (rsa_pkcs1_implicit_rejection). These changes are part of OpenSSL 3.2 and have also been backported to stable versions of various Linux distributions, as well as to the PHP builds provided for Windows since the previous release. All distributors and builders should ensure that this version is used to prevent PHP from being vulnerable. PHP Windows builds for the versions 8.1.29, 8.2.20 and 8.3.8 and above include OpenSSL patches that fix the vulnerability.
Credit: security@php.net
Affected Software | Affected Version | How to fix |
---|---|---|
PHP | >=8.1.0<8.1.29 | |
PHP | >=8.2.0<8.2.20 | |
PHP | >=8.3.0<8.3.8 | |
Fedora | =40 |
Use a recent patched version of OpenSSL.
Sign up to SecAlerts for real-time vulnerability data matched to your software, aggregated from hundreds of sources.
CVE-2024-2408 is considered a high-severity vulnerability due to its potential to allow attackers to exploit the Marvin Attack via the openssl_private_decrypt function.
To fix CVE-2024-2408, update your PHP to a version above 8.1.29, 8.2.20, or 8.3.8 where the vulnerability is patched.
CVE-2024-2408 affects PHP versions 8.1.0 to 8.1.29, 8.2.0 to 8.2.20, and 8.3.0 to 8.3.8.
CVE-2024-2408 exposes the openssl_private_decrypt function to the Marvin Attack when using PKCS1 padding.
CVE-2024-2408 is specifically noted to affect PHP installations on Fedora 40, among others.