]> granicus.if.org Git - python/commitdiff
3.2- fix the incorrect changes made for PATH_INFO value - Issue10484
authorSenthil Kumaran <senthil@uthcode.com>
Tue, 10 Apr 2012 19:15:28 +0000 (03:15 +0800)
committerSenthil Kumaran <senthil@uthcode.com>
Tue, 10 Apr 2012 19:15:28 +0000 (03:15 +0800)
Lib/http/server.py
Lib/test/test_httpservers.py

index 537df90bf28b7cff8e58d63bd9696be0a3b43534..831c79e114a7f6683503b51946744c04fd972f39 100644 (file)
@@ -850,14 +850,7 @@ 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:
-        # 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()
+        tail_part = path_parts.pop()
     else:
         tail_part = ''
     head_parts = []
@@ -952,8 +945,11 @@ class CGIHTTPRequestHandler(SimpleHTTPRequestHandler):
         """
 
         splitpath = _url_collapse_path_split(self.path)
-        if splitpath[0] in self.cgi_directories:
-            self.cgi_info = splitpath
+        joined_path = '/'.join(splitpath)
+        dir_sep = joined_path.find('/',1)
+        head, tail = joined_path[:dir_sep], joined_path[dir_sep+1:]
+        if head in self.cgi_directories:
+            self.cgi_info = head, tail
             return True
         return False
 
index 4d58e4bac3199fc5fda17693efefa810ff6e54aa..e83c048ed940e1a63bed8adc9226b54d2c7036ca 100644 (file)
@@ -377,7 +377,6 @@ 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'),