{"api_version":"1","generated_at":"2026-06-21T20:16:51+00:00","cve":"CVE-2026-44546","urls":{"html":"https://cve.report/CVE-2026-44546","api":"https://cve.report/api/cve/CVE-2026-44546.json","docs":"https://cve.report/api","cve_org":"https://www.cve.org/CVERecord?id=CVE-2026-44546","nvd":"https://nvd.nist.gov/vuln/detail/CVE-2026-44546"},"summary":{"title":"Header injection via WebSocket upgrade parser differential allows ASGI scope header spoofing","description":"daphne before 4.2.2 reconstructs a raw HTTP request from Twisted's parsed headers and feeds it to autobahn for WebSocket handshake processing. Twisted does not treat \\x0b, \\x0c, \\x1c, \\x1d, \\x1e, or \\x85 as header line separators, but autobahn decodes header values to str and calls splitlines(). An attacker can exploit this parser differential to inject additional headers into the ASGI scope passed to the application. daphne now rejects requests with these bytes in any header value with a 400 response.","state":"PUBLISHED","assigner":"DSF","published_at":"2026-06-03 14:16:43","updated_at":"2026-06-15 19:52:47"},"problem_types":["CWE-444","CWE-444 CWE-444 (Inconsistent Interpretation of HTTP Requests -- \"HTTP Request/Response Smuggling\")"],"metrics":[{"version":"3.1","source":"nvd@nist.gov","type":"Primary","score":"5.3","severity":"MEDIUM","vector":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:N","data":{"version":"3.1","vectorString":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:N","baseScore":5.3,"baseSeverity":"MEDIUM","attackVector":"NETWORK","attackComplexity":"LOW","privilegesRequired":"NONE","userInteraction":"NONE","scope":"UNCHANGED","confidentialityImpact":"LOW","integrityImpact":"NONE","availabilityImpact":"NONE"}},{"version":"3.1","source":"6a34fbeb-21d4-45e7-8e0a-62b95bc12c92","type":"Secondary","score":"3.7","severity":"LOW","vector":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:L/I:N/A:N","data":{"version":"3.1","vectorString":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:L/I:N/A:N","baseScore":3.7,"baseSeverity":"LOW","attackVector":"NETWORK","attackComplexity":"HIGH","privilegesRequired":"NONE","userInteraction":"NONE","scope":"UNCHANGED","confidentialityImpact":"LOW","integrityImpact":"NONE","availabilityImpact":"NONE"}},{"version":"3.1","source":"CNA","type":"CVSS","score":"3.7","severity":"LOW","vector":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:L/I:N/A:N","data":{"attackComplexity":"HIGH","attackVector":"NETWORK","availabilityImpact":"NONE","baseScore":3.7,"baseSeverity":"LOW","confidentialityImpact":"LOW","integrityImpact":"NONE","privilegesRequired":"NONE","scope":"UNCHANGED","userInteraction":"NONE","vectorString":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:L/I:N/A:N","version":"3.1"}}],"references":[{"url":"https://github.com/django/daphne/blob/main/CHANGELOG.txt","name":"https://github.com/django/daphne/blob/main/CHANGELOG.txt","refsource":"6a34fbeb-21d4-45e7-8e0a-62b95bc12c92","tags":["Release Notes"],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://www.cve.org/CVERecord?id=CVE-2026-44546","name":"CVE Program record","refsource":"CVE.ORG","tags":["canonical"]},{"url":"https://nvd.nist.gov/vuln/detail/CVE-2026-44546","name":"NVD vulnerability detail","refsource":"NVD","tags":["canonical","analysis"]}],"affected":[{"source":"CNA","vendor":"djangoproject","product":"daphne","version":"affected 4.2.0 4.2.1 python","platforms":[]},{"source":"CNA","vendor":"djangoproject","product":"daphne","version":"unaffected 4.2.2 python","platforms":[]}],"timeline":[{"source":"CNA","time":"2026-04-09T03:00:00.000Z","lang":"en","value":"Initial report received."},{"source":"CNA","time":"2026-05-06T03:00:00.000Z","lang":"en","value":"Vulnerability confirmed."}],"solutions":[],"workarounds":[],"exploits":[],"credits":[{"source":"CNA","value":"Rene Henningsen","lang":"en"},{"source":"CNA","value":"Carlton Gibson","lang":"en"}],"nvd_cpes":[{"cve_year":"2026","cve_id":"44546","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"djangoproject","cpe5":"daphne","cpe6":"*","cpe7":"*","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"*","cpe12":"*","cpe13":"*"}],"vendor_comments":[],"enrichments":{"kev":null,"epss":{"cve_year":"2026","cve_id":"44546","cve":"CVE-2026-44546","epss":"0.001720000","percentile":"0.068160000","score_date":"2026-06-20","updated_at":"2026-06-21 00:13:44"},"legacy_qids":[]},"source_records":{"cve_program":{"containers":{"adp":[{"metrics":[{"other":{"content":{"id":"CVE-2026-44546","options":[{"Exploitation":"none"},{"Automatable":"no"},{"Technical Impact":"partial"}],"role":"CISA Coordinator","timestamp":"2026-06-03T15:45:59.459546Z","version":"2.0.3"},"type":"ssvc"}}],"providerMetadata":{"dateUpdated":"2026-06-03T15:46:08.745Z","orgId":"134c704f-9b21-4f2e-91b3-4a467353bcc0","shortName":"CISA-ADP"},"title":"CISA ADP Vulnrichment"}],"cna":{"affected":[{"collectionURL":"https://pypi.org/project/daphne/","defaultStatus":"unaffected","packageName":"daphne","product":"daphne","repo":"https://github.com/django/daphne/","vendor":"djangoproject","versions":[{"lessThanOrEqual":"4.2.1","status":"affected","version":"4.2.0","versionType":"python"},{"status":"unaffected","version":"4.2.2","versionType":"python"}]}],"credits":[{"lang":"en","type":"reporter","value":"Rene Henningsen"},{"lang":"en","type":"remediation developer","value":"Carlton Gibson"}],"descriptions":[{"lang":"en","supportingMedia":[{"base64":false,"type":"text/html","value":"<p>daphne before 4.2.2 reconstructs a raw HTTP request from Twisted's parsed headers and feeds it to autobahn for WebSocket handshake processing. Twisted does not treat <code>\\x0b</code>, <code>\\x0c</code>, <code>\\x1c</code>, <code>\\x1d</code>, <code>\\x1e</code>, or <code>\\x85</code> as header line separators, but autobahn decodes header values to <code>str</code> and calls <code>splitlines()</code>. An attacker can exploit this parser differential to inject additional headers into the ASGI scope passed to the application. daphne now rejects requests with these bytes in any header value with a 400 response.</p>"}],"value":"daphne before 4.2.2 reconstructs a raw HTTP request from Twisted's parsed headers and feeds it to autobahn for WebSocket handshake processing. Twisted does not treat \\x0b, \\x0c, \\x1c, \\x1d, \\x1e, or \\x85 as header line separators, but autobahn decodes header values to str and calls splitlines(). An attacker can exploit this parser differential to inject additional headers into the ASGI scope passed to the application. daphne now rejects requests with these bytes in any header value with a 400 response."}],"impacts":[{"capecId":"CAPEC-33","descriptions":[{"lang":"en","value":"CAPEC-33: HTTP Request Smuggling"}]}],"metrics":[{"cvssV3_1":{"attackComplexity":"HIGH","attackVector":"NETWORK","availabilityImpact":"NONE","baseScore":3.7,"baseSeverity":"LOW","confidentialityImpact":"LOW","integrityImpact":"NONE","privilegesRequired":"NONE","scope":"UNCHANGED","userInteraction":"NONE","vectorString":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:L/I:N/A:N","version":"3.1"},"format":"CVSS","scenarios":[{"lang":"en","value":"GENERAL"}]}],"problemTypes":[{"descriptions":[{"cweId":"CWE-444","description":"CWE-444 (Inconsistent Interpretation of HTTP Requests -- \"HTTP Request/Response Smuggling\")","lang":"en","type":"CWE"}]}],"providerMetadata":{"dateUpdated":"2026-06-03T13:17:55.283Z","orgId":"6a34fbeb-21d4-45e7-8e0a-62b95bc12c92","shortName":"DSF"},"references":[{"tags":["release-notes"],"url":"https://github.com/django/daphne/blob/main/CHANGELOG.txt"}],"source":{"discovery":"EXTERNAL"},"timeline":[{"lang":"en","time":"2026-04-09T03:00:00.000Z","value":"Initial report received."},{"lang":"en","time":"2026-05-06T03:00:00.000Z","value":"Vulnerability confirmed."}],"title":"Header injection via WebSocket upgrade parser differential allows ASGI scope header spoofing","x_generator":{"engine":"cvelib 1.8.0"}}},"cveMetadata":{"assignerOrgId":"6a34fbeb-21d4-45e7-8e0a-62b95bc12c92","assignerShortName":"DSF","cveId":"CVE-2026-44546","datePublished":"2026-06-03T13:17:55.283Z","dateReserved":"2026-05-06T20:29:54.084Z","dateUpdated":"2026-06-03T15:46:08.745Z","state":"PUBLISHED"},"dataType":"CVE_RECORD","dataVersion":"5.2"},"nvd":{"publishedDate":"2026-06-03 14:16:43","lastModifiedDate":"2026-06-15 19:52:47","problem_types":["CWE-444","CWE-444 CWE-444 (Inconsistent Interpretation of HTTP Requests -- \"HTTP Request/Response Smuggling\")"],"metrics":{"cvssMetricV31":[{"source":"6a34fbeb-21d4-45e7-8e0a-62b95bc12c92","type":"Secondary","cvssData":{"version":"3.1","vectorString":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:L/I:N/A:N","baseScore":3.7,"baseSeverity":"LOW","attackVector":"NETWORK","attackComplexity":"HIGH","privilegesRequired":"NONE","userInteraction":"NONE","scope":"UNCHANGED","confidentialityImpact":"LOW","integrityImpact":"NONE","availabilityImpact":"NONE"},"exploitabilityScore":2.2,"impactScore":1.4},{"source":"nvd@nist.gov","type":"Primary","cvssData":{"version":"3.1","vectorString":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:N","baseScore":5.3,"baseSeverity":"MEDIUM","attackVector":"NETWORK","attackComplexity":"LOW","privilegesRequired":"NONE","userInteraction":"NONE","scope":"UNCHANGED","confidentialityImpact":"LOW","integrityImpact":"NONE","availabilityImpact":"NONE"},"exploitabilityScore":3.9,"impactScore":1.4}]},"configurations":[{"nodes":[{"operator":"OR","negate":false,"cpeMatch":[{"vulnerable":true,"criteria":"cpe:2.3:a:djangoproject:daphne:*:*:*:*:*:*:*:*","versionEndExcluding":"4.2.2","matchCriteriaId":"48E446D3-9A77-40A0-A62A-D3F04DF924AB"}]}]}]},"legacy_mitre":{"record":{"CveYear":"2026","CveId":"44546","Ordinal":"1","Title":"Header injection via WebSocket upgrade parser differential allow","CVE":"CVE-2026-44546","Year":"2026"},"notes":[{"CveYear":"2026","CveId":"44546","Ordinal":"1","NoteData":"daphne before 4.2.2 reconstructs a raw HTTP request from Twisted's parsed headers and feeds it to autobahn for WebSocket handshake processing. Twisted does not treat \\x0b, \\x0c, \\x1c, \\x1d, \\x1e, or \\x85 as header line separators, but autobahn decodes header values to str and calls splitlines(). An attacker can exploit this parser differential to inject additional headers into the ASGI scope passed to the application. daphne now rejects requests with these bytes in any header value with a 400 response.","Type":"Description","Title":"Header injection via WebSocket upgrade parser differential allow"}]}}}