CRITICALCVE-2026-39821Published Modified CNA Go
CVE-2026-39821: Invoking failure to reject ASCII-only Punycode-encoded labels in golang.org/x/net/idna
The ToASCII and ToUnicode functions incorrectly accept Punycode-encoded labels that decode to an ASCII-only label. For example, ToUnicode("xn--example-.com") incorrectly returns the name "example.com" rather than an error. This behavior can lead to privilege escalation in programs using the idna package. For example, a program which performs privilege checks on the ASCII hostname may reject "example.com" but permit "xn--example-.com". If that program subsequently converts the ASCII hostname to Unicode, it will inadvertently permits access to the Unicode name "example.com".
Metrics
- CVSS v3.1
- 9.6
- Severity
- CRITICAL
- Fixed in
- 0.55.0
- Affected Products
- 1
Fix available
0.55.0
Affected packages
- golang.org/x/net / golang.org/x/net/idna< 0.55.0 (from 0)
CVSS Vector
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:H/I:H/A:NReferences