Improper Neutralization of CRLF Sequences in HTTP Headers ('HTTP Request/Response Splitting') vulnerability in ninenines cowlib allows HTTP response splitting via non-VCHAR bytes in structured-fields string values.
cowhttpstructhd:escapestring/2 in cowlib only escapes \ and ", passing all other bytes through verbatim. This creates an encoder/decoder asymmetry: the matching parser accepts only printable ASCII (0x20–0x7E, excluding " and ), but the encoder emits any byte including CR and LF. An application that builds a structured HTTP header via cowhttpstructhd:item/1 (or a higher-level wrapper such as cowhttphd:wtprotocol/1) from attacker-controlled input can have \r\n injected into the serialized header value. Once on the wire, the injected CRLF terminates the current header and any following bytes are interpreted as a new header, enabling HTTP response splitting.
This issue affects cowlib from 2.9.0.
{
"cwe_ids": [
"CWE-113"
],
"cna_assigner": "EEF",
"osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2026/43xxx/CVE-2026-43966.json",
"unresolved_ranges": [
{
"extracted_events": [
{
"last_affected": "a8b793db3d6ffe91d62f81baf41b1dab4cd78fb6"
}
],
"source": "AFFECTED_FIELD"
}
]
}