From b114296f571c0349f3c594ca0e76e97861a469e8 Mon Sep 17 00:00:00 2001 From: JannisBush <33023300+JannisBush@users.noreply.github.com> Date: Thu, 1 Dec 2022 16:56:21 +0100 Subject: [PATCH] Quick fix for #648 --- dpkt/http.py | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/dpkt/http.py b/dpkt/http.py index 19f7bc30..8a6d9b50 100644 --- a/dpkt/http.py +++ b/dpkt/http.py @@ -100,7 +100,7 @@ class Message(dpkt.Packet): def __init__(self, *args, **kwargs): if args: - self.unpack(args[0]) + self.unpack(args[0], **kwargs) else: self.headers = OrderedDict() self.body = b'' @@ -175,7 +175,7 @@ class Request(Message): )) __proto = 'HTTP' - def unpack(self, buf): + def unpack(self, buf, **kwargs): f = BytesIO(buf) line = f.readline().decode("ascii", "ignore") l_ = line.strip().split() @@ -229,7 +229,7 @@ class Response(Message): } __proto = 'HTTP' - def unpack(self, buf): + def unpack(self, buf, head_response=False, **kwargs): f = BytesIO(buf) line = f.readline() l_ = line.strip().decode("ascii", "ignore").split(None, 2) @@ -249,6 +249,8 @@ def unpack(self, buf): # MUST NOT include a message-body. All other responses do include a # message-body, although it MAY be of zero length. is_body_allowed = int(self.status) >= 200 and 204 != int(self.status) != 304 + if head_response: + is_body_allowed = False Message.unpack(self, f.read(), is_body_allowed) def __str__(self):