CVE-2024-58135
Mojolicious Weak HMAC Session Secret Vulnerability
Description
Mojolicious versions from 7.28 through 9.40 for Perl may generate weak HMAC session secrets. When creating a default app with the "mojo generate app" tool, a weak secret is written to the application's configuration file using the insecure rand() function, and used for authenticating and protecting the integrity of the application's sessions. This may allow an attacker to brute force the application's session keys.
INFO
Published Date :
May 3, 2025, 11:15 a.m.
Last Modified :
June 17, 2025, 2:16 p.m.
Source :
9b29abf9-4ab0-4765-b253-1875cd9b441e
Remotely Exploitable :
Yes !
Impact Score :
1.4
Exploitability Score :
3.9
References to Advisories, Solutions, and Tools
Here, you will find a curated list of external links that provide in-depth
information, practical solutions, and valuable tools related to
CVE-2024-58135
.
URL | Resource |
---|---|
https://github.com/hashcat/hashcat/pull/4090 | Issue Tracking Patch |
https://github.com/mojolicious/mojo/pull/2200 | Exploit Issue Tracking Patch |
https://metacpan.org/release/SRI/Mojolicious-7.28/source/lib/Mojolicious/Command/generate/app.pm#L220 | Product |
https://metacpan.org/release/SRI/Mojolicious-9.38/source/lib/Mojolicious/Command/Author/generate/app.pm#L202 | Product |
https://metacpan.org/release/SRI/Mojolicious-9.39/source/lib/Mojo/Util.pm#L181 | Product |
https://perldoc.perl.org/functions/rand | Product |
https://security.metacpan.org/docs/guides/random-data-for-security.html | Technical Description |
We scan GitHub repositories to detect new proof-of-concept exploits. Following list is a collection of public exploits and proof-of-concepts, which have been published on GitHub (sorted by the most recently updated).
Results are limited to the first 15 repositories due to potential performance issues.
The following list is the news that have been mention
CVE-2024-58135
vulnerability anywhere in the article.
The following table lists the changes that have been made to the
CVE-2024-58135
vulnerability over time.
Vulnerability history details can be useful for understanding the evolution of a vulnerability, and for identifying the most recent changes that may impact the vulnerability's severity, exploitability, or other characteristics.
-
Initial Analysis by [email protected]
Jun. 17, 2025
Action Type Old Value New Value Added CPE Configuration OR *cpe:2.3:a:mojolicious:mojolicious:*:*:*:*:*:perl:*:* versions from (including) 7.28 up to (including) 9.40 Added Reference Type CPANSec: https://github.com/hashcat/hashcat/pull/4090 Types: Issue Tracking, Patch Added Reference Type CPANSec: https://github.com/mojolicious/mojo/pull/2200 Types: Exploit, Issue Tracking, Patch Added Reference Type CPANSec: https://metacpan.org/release/SRI/Mojolicious-7.28/source/lib/Mojolicious/Command/generate/app.pm#L220 Types: Product Added Reference Type CPANSec: https://metacpan.org/release/SRI/Mojolicious-9.38/source/lib/Mojolicious/Command/Author/generate/app.pm#L202 Types: Product Added Reference Type CPANSec: https://metacpan.org/release/SRI/Mojolicious-9.39/source/lib/Mojo/Util.pm#L181 Types: Product Added Reference Type CPANSec: https://perldoc.perl.org/functions/rand Types: Product Added Reference Type CPANSec: https://security.metacpan.org/docs/guides/random-data-for-security.html Types: Technical Description -
CVE Modified by 9b29abf9-4ab0-4765-b253-1875cd9b441e
May. 12, 2025
Action Type Old Value New Value Changed Description Mojolicious versions from 7.28 through 9.39 for Perl may generate weak HMAC session secrets. When creating a default app with the "mojo generate app" tool, a weak secret is written to the application's configuration file using the insecure rand() function, and used for authenticating and protecting the integrity of the application's sessions. This may allow an attacker to brute force the application's session keys. Mojolicious versions from 7.28 through 9.40 for Perl may generate weak HMAC session secrets. When creating a default app with the "mojo generate app" tool, a weak secret is written to the application's configuration file using the insecure rand() function, and used for authenticating and protecting the integrity of the application's sessions. This may allow an attacker to brute force the application's session keys. -
CVE Modified by 134c704f-9b21-4f2e-91b3-4a467353bcc0
May. 07, 2025
Action Type Old Value New Value Added CVSS V3.1 AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:N Added CWE CWE-338 -
New CVE Received by 9b29abf9-4ab0-4765-b253-1875cd9b441e
May. 03, 2025
Action Type Old Value New Value Added Description Mojolicious versions from 7.28 through 9.39 for Perl may generate weak HMAC session secrets. When creating a default app with the "mojo generate app" tool, a weak secret is written to the application's configuration file using the insecure rand() function, and used for authenticating and protecting the integrity of the application's sessions. This may allow an attacker to brute force the application's session keys. Added CWE CWE-338 Added Reference https://github.com/hashcat/hashcat/pull/4090 Added Reference https://github.com/mojolicious/mojo/pull/2200 Added Reference https://metacpan.org/release/SRI/Mojolicious-7.28/source/lib/Mojolicious/Command/generate/app.pm#L220 Added Reference https://metacpan.org/release/SRI/Mojolicious-9.38/source/lib/Mojolicious/Command/Author/generate/app.pm#L202 Added Reference https://metacpan.org/release/SRI/Mojolicious-9.39/source/lib/Mojo/Util.pm#L181 Added Reference https://perldoc.perl.org/functions/rand Added Reference https://security.metacpan.org/docs/guides/random-data-for-security.html
CWE - Common Weakness Enumeration
While CVE identifies
specific instances of vulnerabilities, CWE categorizes the common flaws or
weaknesses that can lead to vulnerabilities. CVE-2024-58135
is
associated with the following CWEs:
Common Attack Pattern Enumeration and Classification (CAPEC)
Common Attack Pattern Enumeration and Classification
(CAPEC)
stores attack patterns, which are descriptions of the common attributes and
approaches employed by adversaries to exploit the CVE-2024-58135
weaknesses.