Fixed #126 -- HttpRequest now has a 'raw_post_data' attribute.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@478 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
bdcea2e6ca
commit
fcfb8edc15
|
@ -23,9 +23,9 @@ class ModPythonRequest(httpwrappers.HttpRequest):
|
||||||
def _load_post_and_files(self):
|
def _load_post_and_files(self):
|
||||||
"Populates self._post and self._files"
|
"Populates self._post and self._files"
|
||||||
if self._req.headers_in.has_key('content-type') and self._req.headers_in['content-type'].startswith('multipart'):
|
if self._req.headers_in.has_key('content-type') and self._req.headers_in['content-type'].startswith('multipart'):
|
||||||
self._post, self._files = httpwrappers.parse_file_upload(self._req.headers_in, self._req.read())
|
self._post, self._files = httpwrappers.parse_file_upload(self._req.headers_in, self.raw_post_data)
|
||||||
else:
|
else:
|
||||||
self._post, self._files = httpwrappers.QueryDict(self._req.read()), datastructures.MultiValueDict()
|
self._post, self._files = httpwrappers.QueryDict(self.raw_post_data), datastructures.MultiValueDict()
|
||||||
|
|
||||||
def _get_request(self):
|
def _get_request(self):
|
||||||
if not hasattr(self, '_request'):
|
if not hasattr(self, '_request'):
|
||||||
|
@ -88,6 +88,13 @@ class ModPythonRequest(httpwrappers.HttpRequest):
|
||||||
self._meta[key] = value
|
self._meta[key] = value
|
||||||
return self._meta
|
return self._meta
|
||||||
|
|
||||||
|
def _get_raw_post_data(self):
|
||||||
|
try:
|
||||||
|
return self._raw_post_data
|
||||||
|
except AttributeError:
|
||||||
|
self._raw_post_data = self._req.read()
|
||||||
|
return self._raw_post_data
|
||||||
|
|
||||||
def _load_session_and_user(self):
|
def _load_session_and_user(self):
|
||||||
from django.models.auth import sessions
|
from django.models.auth import sessions
|
||||||
from django.conf.settings import AUTH_SESSION_COOKIE
|
from django.conf.settings import AUTH_SESSION_COOKIE
|
||||||
|
@ -122,6 +129,7 @@ class ModPythonRequest(httpwrappers.HttpRequest):
|
||||||
FILES = property(_get_files)
|
FILES = property(_get_files)
|
||||||
META = property(_get_meta)
|
META = property(_get_meta)
|
||||||
REQUEST = property(_get_request)
|
REQUEST = property(_get_request)
|
||||||
|
raw_post_data = property(_get_raw_post_data)
|
||||||
session = property(_get_session, _set_session)
|
session = property(_get_session, _set_session)
|
||||||
user = property(_get_user, _set_user)
|
user = property(_get_user, _set_user)
|
||||||
|
|
||||||
|
|
|
@ -26,13 +26,12 @@ class WSGIRequest(httpwrappers.HttpRequest):
|
||||||
def _load_post_and_files(self):
|
def _load_post_and_files(self):
|
||||||
# Populates self._post and self._files
|
# Populates self._post and self._files
|
||||||
if self.environ['REQUEST_METHOD'] == 'POST':
|
if self.environ['REQUEST_METHOD'] == 'POST':
|
||||||
post_data = self.environ['wsgi.input'].read(int(self.environ["CONTENT_LENGTH"]))
|
|
||||||
if self.environ.get('CONTENT_TYPE', '').startswith('multipart'):
|
if self.environ.get('CONTENT_TYPE', '').startswith('multipart'):
|
||||||
header_dict = dict([(k, v) for k, v in self.environ.items() if k.startswith('HTTP_')])
|
header_dict = dict([(k, v) for k, v in self.environ.items() if k.startswith('HTTP_')])
|
||||||
header_dict['Content-Type'] = self.environ.get('CONTENT_TYPE', '')
|
header_dict['Content-Type'] = self.environ.get('CONTENT_TYPE', '')
|
||||||
self._post, self._files = httpwrappers.parse_file_upload(header_dict, post_data)
|
self._post, self._files = httpwrappers.parse_file_upload(header_dict, self.raw_post_data)
|
||||||
else:
|
else:
|
||||||
self._post, self._files = httpwrappers.QueryDict(post_data), datastructures.MultiValueDict()
|
self._post, self._files = httpwrappers.QueryDict(self.raw_post_data), datastructures.MultiValueDict()
|
||||||
else:
|
else:
|
||||||
self._post, self._files = httpwrappers.QueryDict(''), datastructures.MultiValueDict()
|
self._post, self._files = httpwrappers.QueryDict(''), datastructures.MultiValueDict()
|
||||||
|
|
||||||
|
@ -70,6 +69,13 @@ class WSGIRequest(httpwrappers.HttpRequest):
|
||||||
self._load_post_and_files()
|
self._load_post_and_files()
|
||||||
return self._files
|
return self._files
|
||||||
|
|
||||||
|
def _get_raw_post_data(self):
|
||||||
|
try:
|
||||||
|
return self._raw_post_data
|
||||||
|
except AttributeError:
|
||||||
|
self._raw_post_data = self.environ['wsgi.input'].read(int(self.environ["CONTENT_LENGTH"]))
|
||||||
|
return self._raw_post_data
|
||||||
|
|
||||||
def _load_session_and_user(self):
|
def _load_session_and_user(self):
|
||||||
from django.models.auth import sessions
|
from django.models.auth import sessions
|
||||||
from django.conf.settings import AUTH_SESSION_COOKIE
|
from django.conf.settings import AUTH_SESSION_COOKIE
|
||||||
|
@ -103,6 +109,7 @@ class WSGIRequest(httpwrappers.HttpRequest):
|
||||||
COOKIES = property(_get_cookies, _set_cookies)
|
COOKIES = property(_get_cookies, _set_cookies)
|
||||||
FILES = property(_get_files)
|
FILES = property(_get_files)
|
||||||
REQUEST = property(_get_request)
|
REQUEST = property(_get_request)
|
||||||
|
raw_post_data = property(_get_raw_post_data)
|
||||||
session = property(_get_session, _set_session)
|
session = property(_get_session, _set_session)
|
||||||
user = property(_get_user, _set_user)
|
user = property(_get_user, _set_user)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue