mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	[3.2.x] Fixed #32713, Fixed CVE-2021-32052 -- Prevented newlines and tabs from being accepted in URLValidator on Python 3.9.5+.
In Python 3.9.5+ urllib.parse() automatically removes ASCII newlines and tabs from URLs [1, 2]. Unfortunately it created an issue in the URLValidator. URLValidator uses urllib.urlsplit() and urllib.urlunsplit() for creating a URL variant with Punycode which no longer contains newlines and tabs in Python 3.9.5+. As a consequence, the regular expression matched the URL (without unsafe characters) and the source value (with unsafe characters) was considered valid. [1] https://bugs.python.org/issue43882 and [2]76cd81d603Backport ofe1e81aa1c4from main.
This commit is contained in:
		| @@ -226,9 +226,15 @@ TEST_DATA = [ | ||||
|     (URLValidator(), None, ValidationError), | ||||
|     (URLValidator(), 56, ValidationError), | ||||
|     (URLValidator(), 'no_scheme', ValidationError), | ||||
|     # Trailing newlines not accepted | ||||
|     # Newlines and tabs are not accepted. | ||||
|     (URLValidator(), 'http://www.djangoproject.com/\n', ValidationError), | ||||
|     (URLValidator(), 'http://[::ffff:192.9.5.5]\n', ValidationError), | ||||
|     (URLValidator(), 'http://www.djangoproject.com/\r', ValidationError), | ||||
|     (URLValidator(), 'http://[::ffff:192.9.5.5]\r', ValidationError), | ||||
|     (URLValidator(), 'http://www.django\rproject.com/', ValidationError), | ||||
|     (URLValidator(), 'http://[::\rffff:192.9.5.5]', ValidationError), | ||||
|     (URLValidator(), 'http://\twww.djangoproject.com/', ValidationError), | ||||
|     (URLValidator(), 'http://\t[::ffff:192.9.5.5]', ValidationError), | ||||
|     # Trailing junk does not take forever to reject | ||||
|     (URLValidator(), 'http://www.asdasdasdasdsadfm.com.br ', ValidationError), | ||||
|     (URLValidator(), 'http://www.asdasdasdasdsadfm.com.br z', ValidationError), | ||||
|   | ||||
		Reference in New Issue
	
	Block a user