mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #2045 - TypeError thrown if a form does not have the correct enctype for uploading
files. It throws a ValidationError now, as it should. git-svn-id: http://code.djangoproject.com/svn/django/trunk@3048 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -146,7 +146,11 @@ def isValidImage(field_data, all_data): | |||||||
|     from PIL import Image |     from PIL import Image | ||||||
|     from cStringIO import StringIO |     from cStringIO import StringIO | ||||||
|     try: |     try: | ||||||
|         Image.open(StringIO(field_data['content'])) |         content = field_data['content'] | ||||||
|  |     except TypeError: | ||||||
|  |         raise ValidationError, gettext("No file was submitted. Check the encoding type on the form.") | ||||||
|  |     try: | ||||||
|  |         Image.open(StringIO(content)) | ||||||
|     except IOError: # Python Imaging Library doesn't recognize it as an image |     except IOError: # Python Imaging Library doesn't recognize it as an image | ||||||
|         raise ValidationError, gettext("Upload a valid image. The file you uploaded was either not an image or a corrupted image.") |         raise ValidationError, gettext("Upload a valid image. The file you uploaded was either not an image or a corrupted image.") | ||||||
|  |  | ||||||
| @@ -366,9 +370,13 @@ class HasAllowableSize: | |||||||
|         self.max_error_message = max_error_message or lazy_inter(gettext_lazy("Make sure your uploaded file is at most %s bytes big."), max_size) |         self.max_error_message = max_error_message or lazy_inter(gettext_lazy("Make sure your uploaded file is at most %s bytes big."), max_size) | ||||||
|  |  | ||||||
|     def __call__(self, field_data, all_data): |     def __call__(self, field_data, all_data): | ||||||
|         if self.min_size is not None and len(field_data['content']) < self.min_size: |         try: | ||||||
|  |             content = field_data['content'] | ||||||
|  |         except TypeError: | ||||||
|  |             raise ValidationError, gettext_lazy("No file was submitted. Check the encoding type on the form.") | ||||||
|  |         if self.min_size is not None and len(content) < self.min_size: | ||||||
|             raise ValidationError, self.min_error_message |             raise ValidationError, self.min_error_message | ||||||
|         if self.max_size is not None and len(field_data['content']) > self.max_size: |         if self.max_size is not None and len(content) > self.max_size: | ||||||
|             raise ValidationError, self.max_error_message |             raise ValidationError, self.max_error_message | ||||||
|  |  | ||||||
| class MatchesRegularExpression: | class MatchesRegularExpression: | ||||||
|   | |||||||
| @@ -641,7 +641,11 @@ class FileUploadField(FormField): | |||||||
|         self.validator_list = [self.isNonEmptyFile] + validator_list |         self.validator_list = [self.isNonEmptyFile] + validator_list | ||||||
|  |  | ||||||
|     def isNonEmptyFile(self, field_data, all_data): |     def isNonEmptyFile(self, field_data, all_data): | ||||||
|         if not field_data['content']: |         try: | ||||||
|  |             content = field_data['content'] | ||||||
|  |         except TypeError: | ||||||
|  |             raise validators.CriticalValidationError, gettext("No file was submitted. Check the encoding type on the form.") | ||||||
|  |         if not content: | ||||||
|             raise validators.CriticalValidationError, gettext("The submitted file is empty.") |             raise validators.CriticalValidationError, gettext("The submitted file is empty.") | ||||||
|  |  | ||||||
|     def render(self, data): |     def render(self, data): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user