From f6922aa43536610bd54f5ef7af7f614dcf92bc04 Mon Sep 17 00:00:00 2001 From: Guido van Rossum Date: Sun, 14 Jan 2001 21:03:01 +0000 Subject: [PATCH] SF Patch #103232 by dougfort: Preserve Nonstandard Port Number in Host Header Dougfort's comments: httplib does not include ':port ' in the HTTP 1.1 'Host:' header. This causes problems if the server is not listening on Port 80. The test case I use is the login to /manage under Zope, with Zope listening on port 8080. Zope returns a with the source URLs lacking the :8080. --- Lib/httplib.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/Lib/httplib.py b/Lib/httplib.py index ae65a11f33f..79789bbbc4f 100644 --- a/Lib/httplib.py +++ b/Lib/httplib.py @@ -441,7 +441,12 @@ class HTTPConnection: # be using HTTP/1.0 and those clients may be issuing this header # themselves. we should NOT issue it twice; some web servers (such # as Apache) barf when they see two Host: headers - self.putheader('Host', self.host) + + # if we need a non-standard port,include it in the header + if self.port == HTTP_PORT: + self.putheader('Host', self.host) + else: + self.putheader('Host', "%s:%s" % (self.host, self.port)) # note: we are assuming that clients will not attempt to set these # headers since *this* library must deal with the