Loading django/middleware/common.py +35 −23 Original line number Diff line number Diff line Loading @@ -53,9 +53,8 @@ class CommonMiddleware(object): # Append a slash if APPEND_SLASH is set and the URL doesn't have a # trailing slash and there is no pattern for the current path if settings.APPEND_SLASH and (not old_url[1].endswith('/')): try: urlresolvers.resolve(request.path_info) except urlresolvers.Resolver404: if (not _is_valid_path(request.path_info) and _is_valid_path("%s/" % request.path_info)): new_url[1] = new_url[1] + '/' if settings.DEBUG and request.method == 'POST': raise RuntimeError, ("" Loading @@ -66,13 +65,9 @@ class CommonMiddleware(object): "slash), or set APPEND_SLASH=False in your Django " "settings.") % (new_url[0], new_url[1]) if new_url != old_url: # Redirect if the target url exists try: urlresolvers.resolve("%s/" % request.path_info) except urlresolvers.Resolver404: pass else: if new_url == old_url: # No redirects required. return if new_url[0]: newurl = "%s://%s%s" % ( request.is_secure() and 'https' or 'http', Loading @@ -83,8 +78,6 @@ class CommonMiddleware(object): newurl += '?' + request.META['QUERY_STRING'] return http.HttpResponsePermanentRedirect(newurl) return None def process_response(self, request, response): "Check for a flat page (for 404s) and calculate the Etag, if needed." if response.status_code == 404: Loading Loading @@ -119,7 +112,9 @@ class CommonMiddleware(object): return response def _is_ignorable_404(uri): "Returns True if a 404 at the given URL *shouldn't* notify the site managers" """ Returns True if a 404 at the given URL *shouldn't* notify the site managers. """ for start in settings.IGNORABLE_404_STARTS: if uri.startswith(start): return True Loading @@ -129,6 +124,23 @@ def _is_ignorable_404(uri): return False def _is_internal_request(domain, referer): "Return true if the referring URL is the same domain as the current request" """ Returns true if the referring URL is the same domain as the current request. """ # Different subdomains are treated as different domains. return referer is not None and re.match("^https?://%s/" % re.escape(domain), referer) def _is_valid_path(path): """ Returns True if the given path resolves against the default URL resolver, False otherwise. This is a convenience method to make working with "is this a match?" cases easier, avoiding unnecessarily indented try...except blocks. """ try: urlresolvers.resolve(path) return True except urlresolvers.Resolver404: return False tests/regressiontests/middleware/tests.py +28 −0 Original line number Diff line number Diff line Loading @@ -89,3 +89,31 @@ class CommonMiddlewareTest(TestCase): self.assertEquals( r['Location'], 'http://testserver/middleware/needsquoting%23/') def test_prepend_www(self): settings.PREPEND_WWW = True settings.APPEND_SLASH = False request = self._get_request('path/') r = CommonMiddleware().process_request(request) self.assertEquals(r.status_code, 301) self.assertEquals( r['Location'], 'http://www.testserver/middleware/path/') def test_prepend_www_append_slash_have_slash(self): settings.PREPEND_WWW = True settings.APPEND_SLASH = True request = self._get_request('slash/') r = CommonMiddleware().process_request(request) self.assertEquals(r.status_code, 301) self.assertEquals(r['Location'], 'http://www.testserver/middleware/slash/') def test_prepend_www_append_slash_slashless(self): settings.PREPEND_WWW = True settings.APPEND_SLASH = True request = self._get_request('slash') r = CommonMiddleware().process_request(request) self.assertEquals(r.status_code, 301) self.assertEquals(r['Location'], 'http://www.testserver/middleware/slash/') Loading
django/middleware/common.py +35 −23 Original line number Diff line number Diff line Loading @@ -53,9 +53,8 @@ class CommonMiddleware(object): # Append a slash if APPEND_SLASH is set and the URL doesn't have a # trailing slash and there is no pattern for the current path if settings.APPEND_SLASH and (not old_url[1].endswith('/')): try: urlresolvers.resolve(request.path_info) except urlresolvers.Resolver404: if (not _is_valid_path(request.path_info) and _is_valid_path("%s/" % request.path_info)): new_url[1] = new_url[1] + '/' if settings.DEBUG and request.method == 'POST': raise RuntimeError, ("" Loading @@ -66,13 +65,9 @@ class CommonMiddleware(object): "slash), or set APPEND_SLASH=False in your Django " "settings.") % (new_url[0], new_url[1]) if new_url != old_url: # Redirect if the target url exists try: urlresolvers.resolve("%s/" % request.path_info) except urlresolvers.Resolver404: pass else: if new_url == old_url: # No redirects required. return if new_url[0]: newurl = "%s://%s%s" % ( request.is_secure() and 'https' or 'http', Loading @@ -83,8 +78,6 @@ class CommonMiddleware(object): newurl += '?' + request.META['QUERY_STRING'] return http.HttpResponsePermanentRedirect(newurl) return None def process_response(self, request, response): "Check for a flat page (for 404s) and calculate the Etag, if needed." if response.status_code == 404: Loading Loading @@ -119,7 +112,9 @@ class CommonMiddleware(object): return response def _is_ignorable_404(uri): "Returns True if a 404 at the given URL *shouldn't* notify the site managers" """ Returns True if a 404 at the given URL *shouldn't* notify the site managers. """ for start in settings.IGNORABLE_404_STARTS: if uri.startswith(start): return True Loading @@ -129,6 +124,23 @@ def _is_ignorable_404(uri): return False def _is_internal_request(domain, referer): "Return true if the referring URL is the same domain as the current request" """ Returns true if the referring URL is the same domain as the current request. """ # Different subdomains are treated as different domains. return referer is not None and re.match("^https?://%s/" % re.escape(domain), referer) def _is_valid_path(path): """ Returns True if the given path resolves against the default URL resolver, False otherwise. This is a convenience method to make working with "is this a match?" cases easier, avoiding unnecessarily indented try...except blocks. """ try: urlresolvers.resolve(path) return True except urlresolvers.Resolver404: return False
tests/regressiontests/middleware/tests.py +28 −0 Original line number Diff line number Diff line Loading @@ -89,3 +89,31 @@ class CommonMiddlewareTest(TestCase): self.assertEquals( r['Location'], 'http://testserver/middleware/needsquoting%23/') def test_prepend_www(self): settings.PREPEND_WWW = True settings.APPEND_SLASH = False request = self._get_request('path/') r = CommonMiddleware().process_request(request) self.assertEquals(r.status_code, 301) self.assertEquals( r['Location'], 'http://www.testserver/middleware/path/') def test_prepend_www_append_slash_have_slash(self): settings.PREPEND_WWW = True settings.APPEND_SLASH = True request = self._get_request('slash/') r = CommonMiddleware().process_request(request) self.assertEquals(r.status_code, 301) self.assertEquals(r['Location'], 'http://www.testserver/middleware/slash/') def test_prepend_www_append_slash_slashless(self): settings.PREPEND_WWW = True settings.APPEND_SLASH = True request = self._get_request('slash') r = CommonMiddleware().process_request(request) self.assertEquals(r.status_code, 301) self.assertEquals(r['Location'], 'http://www.testserver/middleware/slash/')