diff options
author | Senthil Kumaran <senthil@uthcode.com> | 2012-04-10 19:16:16 (GMT) |
---|---|---|
committer | Senthil Kumaran <senthil@uthcode.com> | 2012-04-10 19:16:16 (GMT) |
commit | d05853da974d4061d477e120898df448748f6d7d (patch) | |
tree | a996c544cfab76ccd05c9e1ca9b32e53b82d49a4 /Lib/http | |
parent | eba2428002c7c98ba98141f710322904a8928b47 (diff) | |
parent | dbb369d0efaefeccb460ffb74b1617bea1d429f7 (diff) | |
download | cpython-d05853da974d4061d477e120898df448748f6d7d.zip cpython-d05853da974d4061d477e120898df448748f6d7d.tar.gz cpython-d05853da974d4061d477e120898df448748f6d7d.tar.bz2 |
merge - fix the incorrect changes made for PATH_INFO value - Issue10484
Diffstat (limited to 'Lib/http')
-rw-r--r-- | Lib/http/server.py | 16 |
1 files changed, 6 insertions, 10 deletions
diff --git a/Lib/http/server.py b/Lib/http/server.py index 8326f30..4c0e6cd 100644 --- a/Lib/http/server.py +++ b/Lib/http/server.py @@ -865,14 +865,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 = [] @@ -963,8 +956,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 |