CVE-2026-28810: Predictable DNS Transaction IDs Enable Cache Poisoning in Built-in Resolver
Generation of Predictable Numbers or Identifiers vulnerability in Erlang/OTP kernel (inet_res, inet_db modules) allows DNS Cache Poisoning. The built-in DNS resolver (inet_res) uses a sequential, process-global 16-bit transaction ID for UDP queries and does not implement source port randomization. Response validation relies almost entirely on this ID, making DNS cache poisoning practical for an attacker who can observe one query or predict the next ID. This conflicts with RFC 5452 recommendations for mitigating forged DNS answers. inet_res is intended for use in trusted network environments and with trusted recursive resolvers. Earlier documentation did not clearly state this deployment assumption, which could lead users to deploy the resolver in environments where spoofed DNS responses are possible. This vulnerability is associated with program files lib/kernel/src/inet_db.erl and lib/kernel/src/inet_res.erl. This issue affects OTP from OTP 17.0 until OTP 28.4.2, 27.3.4.10 and 26.2.5.19 corresponding to kernel from 3.0 until 10.6.2, 10.2.7.4 and 9.2.4.11.
Affected Software
Remediation
Event History
Frequently Asked Questions
What is the severity of CVE-2026-28810?
CVE-2026-28810 has been classified as a medium severity vulnerability.
How do I fix CVE-2026-28810?
To fix CVE-2026-28810, you should upgrade your Erlang/OTP and OTP kernel versions to the latest patched releases.
Which versions are affected by CVE-2026-28810?
CVE-2026-28810 affects Erlang/OTP versions from 17.0 up to 28.4.2 and OTP kernel versions from 3.0 to 10.6.2.
What type of attack is possible with CVE-2026-28810?
CVE-2026-28810 allows attackers to perform DNS cache poisoning due to predictable DNS transaction IDs.
Who is affected by CVE-2026-28810?
Developers and organizations using vulnerable versions of Erlang/OTP and its kernel are at risk from CVE-2026-28810.