mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #9948 -- Corrected URLField validation to match RFC1035 (URL analog of #9890). Thanks to kratorius for the report and fix.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@10574 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -533,7 +533,7 @@ class ImageField(FileField): | |||||||
|  |  | ||||||
| url_re = re.compile( | url_re = re.compile( | ||||||
|     r'^https?://' # http:// or https:// |     r'^https?://' # http:// or https:// | ||||||
|     r'(?:(?:[A-Z0-9-]+\.)+[A-Z]{2,6}|' #domain... |     r'(?:(?:[A-Z0-9]+(?:-*[A-Z0-9]+)*\.)+[A-Z]{2,6}|' #domain... | ||||||
|     r'localhost|' #localhost... |     r'localhost|' #localhost... | ||||||
|     r'\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})' # ...or ip |     r'\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})' # ...or ip | ||||||
|     r'(?::\d+)?' # optional port |     r'(?::\d+)?' # optional port | ||||||
|   | |||||||
| @@ -900,6 +900,10 @@ u'http://example.com/' | |||||||
| u'http://www.example.com/' | u'http://www.example.com/' | ||||||
| >>> f.clean('http://www.example.com:8000/test') | >>> f.clean('http://www.example.com:8000/test') | ||||||
| u'http://www.example.com:8000/test' | u'http://www.example.com:8000/test' | ||||||
|  | >>> f.clean('valid-with-hyphens.com') | ||||||
|  | u'http://valid-with-hyphens.com/' | ||||||
|  | >>> f.clean('subdomain.domain.com') | ||||||
|  | u'http://subdomain.domain.com/' | ||||||
| >>> f.clean('http://200.8.9.10') | >>> f.clean('http://200.8.9.10') | ||||||
| u'http://200.8.9.10/' | u'http://200.8.9.10/' | ||||||
| >>> f.clean('http://200.8.9.10:8000/test') | >>> f.clean('http://200.8.9.10:8000/test') | ||||||
| @@ -924,6 +928,24 @@ ValidationError: [u'Enter a valid URL.'] | |||||||
| Traceback (most recent call last): | Traceback (most recent call last): | ||||||
| ... | ... | ||||||
| ValidationError: [u'Enter a valid URL.'] | ValidationError: [u'Enter a valid URL.'] | ||||||
|  | >>> f.clean('http://invalid-.com') | ||||||
|  | Traceback (most recent call last): | ||||||
|  | ... | ||||||
|  | ValidationError: [u'Enter a valid URL.'] | ||||||
|  | >>> f.clean('http://-invalid.com') | ||||||
|  | Traceback (most recent call last): | ||||||
|  | ... | ||||||
|  | ValidationError: [u'Enter a valid URL.'] | ||||||
|  | >>> f.clean('http://inv-.alid-.com') | ||||||
|  | Traceback (most recent call last): | ||||||
|  | ... | ||||||
|  | ValidationError: [u'Enter a valid URL.'] | ||||||
|  | >>> f.clean('http://inv-.-alid.com') | ||||||
|  | Traceback (most recent call last): | ||||||
|  | ... | ||||||
|  | ValidationError: [u'Enter a valid URL.'] | ||||||
|  | >>> f.clean('http://valid-----hyphens.com') | ||||||
|  | u'http://valid-----hyphens.com/' | ||||||
|  |  | ||||||
| >>> f = URLField(required=False) | >>> f = URLField(required=False) | ||||||
| >>> f.clean('') | >>> f.clean('') | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user