changeset: 97436:11e9f34169d1 branch: 3.4 parent: 97429:0c5af3e398f0 user: Victor Stinner date: Tue Aug 18 10:21:10 2015 -0700 files: Lib/cgi.py Lib/test/test_cgi.py Misc/ACKS Misc/NEWS description: cgi.FieldStorage.read_multi ignores Content-Length Issue #24764: cgi.FieldStorage.read_multi() now ignores the Content-Length header in part headers. Patch written by Peter Landry and reviewed by Pierre Quentel. diff -r 0c5af3e398f0 -r 11e9f34169d1 Lib/cgi.py --- a/Lib/cgi.py Mon Aug 17 23:38:34 2015 -0700 +++ b/Lib/cgi.py Tue Aug 18 10:21:10 2015 -0700 @@ -714,6 +714,11 @@ self.bytes_read += len(hdr_text) parser.feed(hdr_text.decode(self.encoding, self.errors)) headers = parser.close() + + # Some clients add Content-Length for part headers, ignore them + if 'content-length' in headers: + del headers['content-length'] + part = klass(self.fp, headers, ib, environ, keep_blank_values, strict_parsing,self.limit-self.bytes_read, self.encoding, self.errors) diff -r 0c5af3e398f0 -r 11e9f34169d1 Lib/test/test_cgi.py --- a/Lib/test/test_cgi.py Mon Aug 17 23:38:34 2015 -0700 +++ b/Lib/test/test_cgi.py Tue Aug 18 10:21:10 2015 -0700 @@ -326,6 +326,25 @@ got = getattr(files[x], k) self.assertEqual(got, exp) + def test_fieldstorage_part_content_length(self): + BOUNDARY = "JfISa01" + POSTDATA = """--JfISa01 +Content-Disposition: form-data; name="submit-name" +Content-Length: 5 + +Larry +--JfISa01""" + env = { + 'REQUEST_METHOD': 'POST', + 'CONTENT_TYPE': 'multipart/form-data; boundary={}'.format(BOUNDARY), + 'CONTENT_LENGTH': str(len(POSTDATA))} + fp = BytesIO(POSTDATA.encode('latin-1')) + fs = cgi.FieldStorage(fp, environ=env, encoding="latin-1") + self.assertEqual(len(fs.list), 1) + self.assertEqual(fs.list[0].name, 'submit-name') + self.assertEqual(fs.list[0].value, 'Larry') + + _qs_result = { 'key1': 'value1', 'key2': ['value2x', 'value2y'], diff -r 0c5af3e398f0 -r 11e9f34169d1 Misc/ACKS --- a/Misc/ACKS Mon Aug 17 23:38:34 2015 -0700 +++ b/Misc/ACKS Tue Aug 18 10:21:10 2015 -0700 @@ -773,6 +773,7 @@ Valerie Lambert Jean-Baptiste "Jiba" Lamy Ronan Lamy +Peter Landry Torsten Landschoff Ɓukasz Langa Tino Lange diff -r 0c5af3e398f0 -r 11e9f34169d1 Misc/NEWS --- a/Misc/NEWS Mon Aug 17 23:38:34 2015 -0700 +++ b/Misc/NEWS Tue Aug 18 10:21:10 2015 -0700 @@ -75,6 +75,10 @@ Library ------- +- Issue #24764: cgi.FieldStorage.read_multi() now ignores the Content-Length + header in part headers. Patch written by Peter Landry and reviewed by Pierre + Quentel. + - Issue #24774: Fix docstring in http.server.test. Patch from Chiu-Hsiang Hsu. - Issue #21159: Improve message in configparser.InterpolationMissingOptionError.