Slightly changed the way we handle non-UTF-8 encoded URIs (see [6475]). Made it
easier to subclass the current behaviour, if needed. Fixed #5738. git-svn-id: http://code.djangoproject.com/svn/django/trunk@6550 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
e60c26d5bb
commit
f34935c37f
|
@ -14,7 +14,7 @@ import os
|
||||||
class ModPythonRequest(http.HttpRequest):
|
class ModPythonRequest(http.HttpRequest):
|
||||||
def __init__(self, req):
|
def __init__(self, req):
|
||||||
self._req = req
|
self._req = req
|
||||||
self.path = force_unicode(req.uri, errors='ignore')
|
self.path = force_unicode(req.uri)
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
# Since this is called as part of error handling, we need to be very
|
# Since this is called as part of error handling, we need to be very
|
||||||
|
@ -136,6 +136,8 @@ class ModPythonRequest(http.HttpRequest):
|
||||||
method = property(_get_method)
|
method = property(_get_method)
|
||||||
|
|
||||||
class ModPythonHandler(BaseHandler):
|
class ModPythonHandler(BaseHandler):
|
||||||
|
request_class = ModPythonRequest
|
||||||
|
|
||||||
def __call__(self, req):
|
def __call__(self, req):
|
||||||
# mod_python fakes the environ, and thus doesn't process SetEnv. This fixes that
|
# mod_python fakes the environ, and thus doesn't process SetEnv. This fixes that
|
||||||
os.environ.update(req.subprocess_env)
|
os.environ.update(req.subprocess_env)
|
||||||
|
@ -150,13 +152,16 @@ class ModPythonHandler(BaseHandler):
|
||||||
|
|
||||||
dispatcher.send(signal=signals.request_started)
|
dispatcher.send(signal=signals.request_started)
|
||||||
try:
|
try:
|
||||||
request = ModPythonRequest(req)
|
try:
|
||||||
response = self.get_response(request)
|
request = self.request_class(req)
|
||||||
|
except UnicodeDecodeError:
|
||||||
# Apply response middleware
|
response = http.HttpResponseBadRequest()
|
||||||
for middleware_method in self._response_middleware:
|
else:
|
||||||
response = middleware_method(request, response)
|
response = self.get_response(request)
|
||||||
|
|
||||||
|
# Apply response middleware
|
||||||
|
for middleware_method in self._response_middleware:
|
||||||
|
response = middleware_method(request, response)
|
||||||
finally:
|
finally:
|
||||||
dispatcher.send(signal=signals.request_finished)
|
dispatcher.send(signal=signals.request_finished)
|
||||||
|
|
||||||
|
|
|
@ -75,7 +75,7 @@ def safe_copyfileobj(fsrc, fdst, length=16*1024, size=0):
|
||||||
class WSGIRequest(http.HttpRequest):
|
class WSGIRequest(http.HttpRequest):
|
||||||
def __init__(self, environ):
|
def __init__(self, environ):
|
||||||
self.environ = environ
|
self.environ = environ
|
||||||
self.path = force_unicode(environ['PATH_INFO'], errors='ignore')
|
self.path = force_unicode(environ['PATH_INFO'])
|
||||||
self.META = environ
|
self.META = environ
|
||||||
self.method = environ['REQUEST_METHOD'].upper()
|
self.method = environ['REQUEST_METHOD'].upper()
|
||||||
|
|
||||||
|
@ -179,6 +179,7 @@ class WSGIRequest(http.HttpRequest):
|
||||||
|
|
||||||
class WSGIHandler(BaseHandler):
|
class WSGIHandler(BaseHandler):
|
||||||
initLock = Lock()
|
initLock = Lock()
|
||||||
|
request_class = WSGIRequest
|
||||||
|
|
||||||
def __call__(self, environ, start_response):
|
def __call__(self, environ, start_response):
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
@ -194,13 +195,16 @@ class WSGIHandler(BaseHandler):
|
||||||
|
|
||||||
dispatcher.send(signal=signals.request_started)
|
dispatcher.send(signal=signals.request_started)
|
||||||
try:
|
try:
|
||||||
request = WSGIRequest(environ)
|
try:
|
||||||
response = self.get_response(request)
|
request = self.request_class(environ)
|
||||||
|
except UnicodeDecodeError:
|
||||||
# Apply response middleware
|
response = http.HttpResponseBadRequest()
|
||||||
for middleware_method in self._response_middleware:
|
else:
|
||||||
response = middleware_method(request, response)
|
response = self.get_response(request)
|
||||||
|
|
||||||
|
# Apply response middleware
|
||||||
|
for middleware_method in self._response_middleware:
|
||||||
|
response = middleware_method(request, response)
|
||||||
finally:
|
finally:
|
||||||
dispatcher.send(signal=signals.request_finished)
|
dispatcher.send(signal=signals.request_finished)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue