diff options
author | Jeremy Hylton <jeremy@alum.mit.edu> | 2009-03-27 18:31:36 (GMT) |
---|---|---|
committer | Jeremy Hylton <jeremy@alum.mit.edu> | 2009-03-27 18:31:36 (GMT) |
commit | 98eb6c283881168adbedf37bb34300c39954397a (patch) | |
tree | fcf13a785b31d4a0bc7e05d8117fab7bc64de2fe | |
parent | 914ab45d0a976ba43143db86c3e560efed52e0ff (diff) | |
download | cpython-98eb6c283881168adbedf37bb34300c39954397a.zip cpython-98eb6c283881168adbedf37bb34300c39954397a.tar.gz cpython-98eb6c283881168adbedf37bb34300c39954397a.tar.bz2 |
Fix compatibility issue with HTTPMessage class.
The server needs to use MessageClass to parse.
-rw-r--r-- | Lib/http/client.py | 5 | ||||
-rw-r--r-- | Lib/http/server.py | 3 |
2 files changed, 4 insertions, 4 deletions
diff --git a/Lib/http/client.py b/Lib/http/client.py index 1fe010c..5e091b8 100644 --- a/Lib/http/client.py +++ b/Lib/http/client.py @@ -213,7 +213,6 @@ class HTTPMessage(email.message.Message): occurrences are returned. Case is not important in the header name. """ - # XXX: copied from rfc822.Message for compatibility name = name.lower() + ':' n = len(name) lst = [] @@ -227,7 +226,7 @@ class HTTPMessage(email.message.Message): lst.append(line) return lst -def parse_headers(fp): +def parse_headers(fp, _class=HTTPMessage): """Parses only RFC2822 headers from a file pointer. email Parser wants to see strings rather than bytes. @@ -245,7 +244,7 @@ def parse_headers(fp): break hstring = b''.join(headers).decode('iso-8859-1') - return email.parser.Parser(_class=HTTPMessage).parsestr(hstring) + return email.parser.Parser(_class=_class).parsestr(hstring) class HTTPResponse(io.RawIOBase): diff --git a/Lib/http/server.py b/Lib/http/server.py index 897908e..31153f4 100644 --- a/Lib/http/server.py +++ b/Lib/http/server.py @@ -313,7 +313,8 @@ class BaseHTTPRequestHandler(socketserver.StreamRequestHandler): self.command, self.path, self.request_version = command, path, version # Examine the headers and look for a Connection directive. - self.headers = http.client.parse_headers(self.rfile) + self.headers = http.client.parse_headers(self.rfile, + _class=self.MessageClass) conntype = self.headers.get('Connection', "") if conntype.lower() == 'close': |