]> granicus.if.org Git - python/commitdiff
2.7 - Issue #10484: Fix the CGIHTTPServer's PATH_INFO handling problem
authorSenthil Kumaran <senthil@uthcode.com>
Fri, 16 Mar 2012 08:07:16 +0000 (01:07 -0700)
committerSenthil Kumaran <senthil@uthcode.com>
Fri, 16 Mar 2012 08:07:16 +0000 (01:07 -0700)
Lib/CGIHTTPServer.py
Lib/test/test_httpservers.py
Misc/NEWS

index 13ca0b514bf2320e44fbfedeaf48d774cfc56f17..2ca8217bcb27f29407b830ef3986a50338d171bd 100644 (file)
@@ -323,7 +323,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 = []
index 97abdf569292756173029b2ffb120763ff39f4dd..a7752d927676393b7788f732259766a70a21e45f 100644 (file)
@@ -429,6 +429,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'),
index 376d8d31eb4c56dba8e39b9007ee61d00d37e1c8..b8edcaa831eb4848d8878e1008ca8ffe77be38dd 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -20,6 +20,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 #5219: Prevent event handler cascade in IDLE.