mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #19036 -- Fixed base64 uploads decoding
Thanks anthony at adsorbtion.org for the report, and johannesl for bringing the patch up-to-date.
This commit is contained in:
		| @@ -199,6 +199,12 @@ class MultiPartParser(object): | ||||
|                         for chunk in field_stream: | ||||
|                             if transfer_encoding == 'base64': | ||||
|                                 # We only special-case base64 transfer encoding | ||||
|                                 # We should always read base64 streams by multiple of 4 | ||||
|                                 over_bytes = len(chunk) % 4 | ||||
|                                 if over_bytes: | ||||
|                                     over_chunk = field_stream.read(4 - over_bytes) | ||||
|                                     chunk += over_chunk | ||||
|  | ||||
|                                 try: | ||||
|                                     chunk = base64.b64decode(chunk) | ||||
|                                 except Exception as e: | ||||
|   | ||||
| @@ -74,15 +74,14 @@ class FileUploadTests(TestCase): | ||||
|  | ||||
|         self.assertEqual(response.status_code, 200) | ||||
|  | ||||
|     def test_base64_upload(self): | ||||
|         test_string = "This data will be transmitted base64-encoded." | ||||
|     def _test_base64_upload(self, content): | ||||
|         payload = client.FakePayload("\r\n".join([ | ||||
|             '--' + client.BOUNDARY, | ||||
|             'Content-Disposition: form-data; name="file"; filename="test.txt"', | ||||
|             'Content-Type: application/octet-stream', | ||||
|             'Content-Transfer-Encoding: base64', | ||||
|             '',])) | ||||
|         payload.write(b"\r\n" + base64.b64encode(force_bytes(test_string)) + b"\r\n") | ||||
|         payload.write(b"\r\n" + base64.b64encode(force_bytes(content)) + b"\r\n") | ||||
|         payload.write('--' + client.BOUNDARY + '--\r\n') | ||||
|         r = { | ||||
|             'CONTENT_LENGTH': len(payload), | ||||
| @@ -94,7 +93,13 @@ class FileUploadTests(TestCase): | ||||
|         response = self.client.request(**r) | ||||
|         received = json.loads(response.content.decode('utf-8')) | ||||
|  | ||||
|         self.assertEqual(received['file'], test_string) | ||||
|         self.assertEqual(received['file'], content) | ||||
|  | ||||
|     def test_base64_upload(self): | ||||
|         self._test_base64_upload("This data will be transmitted base64-encoded.") | ||||
|  | ||||
|     def test_big_base64_upload(self): | ||||
|         self._test_base64_upload("Big data" * 68000)  # > 512Kb | ||||
|  | ||||
|     def test_unicode_file_name(self): | ||||
|         tdir = sys_tempfile.mkdtemp() | ||||
|   | ||||
		Reference in New Issue
	
	Block a user