summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2001-08-17 17:24:29 (GMT)
committerGuido van Rossum <guido@python.org>2001-08-17 17:24:29 (GMT)
commit70297d3bd4e33c704f5de976684b46ba796fbf51 (patch)
treea1987324d4ad93381bd4d6804c1d446fe0e861c4 /Lib
parent2dc07946bfacd57b27ae6d180a9e3a5d7cbe8b58 (diff)
downloadcpython-70297d3bd4e33c704f5de976684b46ba796fbf51.zip
cpython-70297d3bd4e33c704f5de976684b46ba796fbf51.tar.gz
cpython-70297d3bd4e33c704f5de976684b46ba796fbf51.tar.bz2
Change the 227 response parser to use a more liberal regular
expression. This is needed for certain servers that (in violation of the standard) don't return the parentheses in the response. This fixes SF bug #441712 by Henrik Weber (not exactly using his patch).
Diffstat (limited to 'Lib')
-rw-r--r--Lib/ftplib.py16
1 files changed, 9 insertions, 7 deletions
diff --git a/Lib/ftplib.py b/Lib/ftplib.py
index fda7864..4aa6244 100644
--- a/Lib/ftplib.py
+++ b/Lib/ftplib.py
@@ -551,6 +551,8 @@ def parse150(resp):
return None
+_227_re = None
+
def parse227(resp):
'''Parse the '227' response for a PASV request.
Raises error_proto if it does not contain '(h1,h2,h3,h4,p1,p2)'
@@ -558,14 +560,14 @@ def parse227(resp):
if resp[:3] != '227':
raise error_reply, resp
- left = resp.find('(')
- if left < 0: raise error_proto, resp
- right = resp.find(')', left + 1)
- if right < 0:
- raise error_proto, resp # should contain '(h1,h2,h3,h4,p1,p2)'
- numbers = resp[left+1:right].split(',')
- if len(numbers) != 6:
+ global _227_re
+ if _227_re is None:
+ import re
+ _227_re = re.compile(r'(\d+),(\d+),(\d+),(\d+),(\d+),(\d+)')
+ m = _227_re.search(resp)
+ if not m:
raise error_proto, resp
+ numbers = m.groups()
host = '.'.join(numbers[:4])
port = (int(numbers[4]) << 8) + int(numbers[5])
return host, port