AI description
CVE-2025-15604 identifies a cryptographic weakness within the `random_string` function of the Perl web framework Amon2, affecting versions prior to 6.17. The vulnerability stems from the use of predictable random number generation methods when the preferred entropy source, `/dev/urandom`, is unavailable. Specifically, Amon2 versions 6.06 through 6.16 attempt to read from `/dev/urandom`, but if it's not accessible, they fall back to generating bytes by concatenating a SHA-1 hash seeded with the built-in Perl `rand()` function, the process ID (PID), and the high-resolution epoch time. This fallback mechanism utilizes elements that are considered predictable, potentially allowing attackers to guess or reproduce tokens, which could lead to issues such as session hijacking, cookie forgery, or bypassing Cross-Site Request Forgery (CSRF) protections.
- Description
- Amon2 versions before 6.17 for Perl use an insecure random_string implementation for security functions. In versions 6.06 through 6.16, the random_string function will attempt to read bytes from the /dev/urandom device, but if that is unavailable then it generates bytes by concatenating a SHA-1 hash seeded with the built-in rand() function, the PID, and the high resolution epoch time. The PID will come from a small set of numbers, and the epoch time may be guessed, if it is not leaked from the HTTP Date header. The built-in rand function is unsuitable for cryptographic usage. Before version 6.06, there was no fallback when /dev/urandom was not available. Before version 6.04, the random_string function used the built-in rand() function to generate a mixed-case alphanumeric string. This function may be used for generating session ids, generating secrets for signing or encrypting cookie session data and generating tokens used for Cross Site Request Forgery (CSRF) protection.
- Source
- 9b29abf9-4ab0-4765-b253-1875cd9b441e
- NVD status
- Modified
- Products
- amon2
CVSS 3.1
- Type
- Primary
- Base score
- 9.8
- Impact score
- 5.9
- Exploitability score
- 3.9
- Vector string
- CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
- Severity
- CRITICAL
- 9b29abf9-4ab0-4765-b253-1875cd9b441e
- CWE-338
- Hype score
- Not currently trending
Attention, elevated activities detected targeting TOKUHIROM Amon2 (CVE-2025-15604) https://t.co/Byp9CQbxir
@vuldb
29 Mar 2026
169 Impressions
0 Retweets
0 Likes
0 Bookmarks
0 Replies
0 Quotes
CVE-2025-15604 Amon2 versions before 6.17 for Perl use an insecure random_string implementation for security functions. In versions 6.06 through 6.16, the random_string function wi… https://t.co/xIGMBmJiU0
@CVEnew
29 Mar 2026
99 Impressions
0 Retweets
0 Likes
0 Bookmarks
0 Replies
0 Quotes
Perl CPAN CVE-2025-15604: Amon2 versions before 6.17 use an insecure random_string implementation for security functions https://t.co/vl2ZSjYQn2 CVE-2026-3256: HTTP::Session versions through 0.53 defaults to using insecurely generated session ids https://t.co/WILUcElIQS
@oss_security
29 Mar 2026
550 Impressions
0 Retweets
4 Likes
0 Bookmarks
0 Replies
0 Quotes
[
{
"nodes": [
{
"cpeMatch": [
{
"criteria": "cpe:2.3:a:tokuhirom:amon2:*:*:*:*:*:perl:*:*",
"matchCriteriaId": "0920218A-C374-46FB-A8C8-FC92ACFB73DB",
"versionEndExcluding": "6.17",
"vulnerable": true
}
],
"negate": false,
"operator": "OR"
}
]
}
]