diff options
author | Senthil Kumaran <senthil@uthcode.com> | 2012-03-16 08:13:50 (GMT) |
---|---|---|
committer | Senthil Kumaran <senthil@uthcode.com> | 2012-03-16 08:13:50 (GMT) |
commit | be3f851411f54b71251743997c1e8b2485f99de2 (patch) | |
tree | 349ace882898ece4e1d3b0a145f7dee31f92331f | |
parent | 604c4ff43de7246c5103ec7b9f581a819da70b33 (diff) | |
download | cpython-be3f851411f54b71251743997c1e8b2485f99de2.zip cpython-be3f851411f54b71251743997c1e8b2485f99de2.tar.gz cpython-be3f851411f54b71251743997c1e8b2485f99de2.tar.bz2 |
closes issue10484 - Fix the http.server's cgi PATH_INFO handling problem
-rw-r--r-- | Lib/http/server.py | 9 | ||||
-rw-r--r-- | Lib/test/test_httpservers.py | 1 | ||||
-rw-r--r-- | Misc/NEWS | 2 |
3 files changed, 11 insertions, 1 deletions
diff --git a/Lib/http/server.py b/Lib/http/server.py index 6642729..537df90 100644 --- a/Lib/http/server.py +++ b/Lib/http/server.py @@ -850,7 +850,14 @@ def _url_collapse_path_split(path): # Filter out blank non trailing parts before consuming the '..'. path_parts = [part for part in path_parts[:-1] if part] + path_parts[-1:] if path_parts: - tail_part = path_parts.pop() + # Special case for CGI's for PATH_INFO + if path.startswith('/cgi-bin') or path.startswith('/htbin'): + tail_part = [] + while path_parts[-1] not in ('cgi-bin','htbin'): + tail_part.insert(0,path_parts.pop()) + tail_part = "/".join(tail_part) + else: + tail_part = path_parts.pop() else: tail_part = '' head_parts = [] diff --git a/Lib/test/test_httpservers.py b/Lib/test/test_httpservers.py index e83c048..4d58e4b 100644 --- a/Lib/test/test_httpservers.py +++ b/Lib/test/test_httpservers.py @@ -377,6 +377,7 @@ class CGIHTTPServerTestCase(BaseTestCase): '/.//': ('/', ''), 'cgi-bin/file1.py': ('/cgi-bin', 'file1.py'), '/cgi-bin/file1.py': ('/cgi-bin', 'file1.py'), + '/cgi-bin/file1.py/PATH-INFO': ('/cgi-bin', 'file1.py/PATH-INFO'), 'a': ('/', 'a'), '/a': ('/', 'a'), '//a': ('/', 'a'), @@ -22,6 +22,8 @@ Core and Builtins Library ------- +- Issue #10484: Fix the CGIHTTPServer's PATH_INFO handling problem. + - Issue #11199: Fix the with urllib which hangs on particular ftp urls. - Issue #14062: Header objects now correctly respect the 'linesep' setting |