mirror of https://github.com/django/django.git
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):
|
||||
"Populates self._post and self._files"
|
||||
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:
|
||||
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):
|
||||
if not hasattr(self, '_request'):
|
||||
|
@ -88,6 +88,13 @@ class ModPythonRequest(httpwrappers.HttpRequest):
|
|||
self._meta[key] = value
|
||||
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):
|
||||
from django.models.auth import sessions
|
||||
from django.conf.settings import AUTH_SESSION_COOKIE
|
||||
|
@ -122,6 +129,7 @@ class ModPythonRequest(httpwrappers.HttpRequest):
|
|||
FILES = property(_get_files)
|
||||
META = property(_get_meta)
|
||||
REQUEST = property(_get_request)
|
||||
raw_post_data = property(_get_raw_post_data)
|
||||
session = property(_get_session, _set_session)
|
||||
user = property(_get_user, _set_user)
|
||||
|
||||
|
|
|
@ -26,13 +26,12 @@ class WSGIRequest(httpwrappers.HttpRequest):
|
|||
def _load_post_and_files(self):
|
||||
# Populates self._post and self._files
|
||||
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'):
|
||||
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', '')
|
||||
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:
|
||||
self._post, self._files = httpwrappers.QueryDict(post_data), datastructures.MultiValueDict()
|
||||
self._post, self._files = httpwrappers.QueryDict(self.raw_post_data), datastructures.MultiValueDict()
|
||||
else:
|
||||
self._post, self._files = httpwrappers.QueryDict(''), datastructures.MultiValueDict()
|
||||
|
||||
|
@ -70,6 +69,13 @@ class WSGIRequest(httpwrappers.HttpRequest):
|
|||
self._load_post_and_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):
|
||||
from django.models.auth import sessions
|
||||
from django.conf.settings import AUTH_SESSION_COOKIE
|
||||
|
@ -103,6 +109,7 @@ class WSGIRequest(httpwrappers.HttpRequest):
|
|||
COOKIES = property(_get_cookies, _set_cookies)
|
||||
FILES = property(_get_files)
|
||||
REQUEST = property(_get_request)
|
||||
raw_post_data = property(_get_raw_post_data)
|
||||
session = property(_get_session, _set_session)
|
||||
user = property(_get_user, _set_user)
|
||||
|
||||
|
|
Loading…
Reference in New Issue