mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-08-08 06:14:47 +03:00
Merge 290de9695a
into 5833a1847f
This commit is contained in:
commit
a6ac5cdec6
|
@ -380,29 +380,37 @@ class Request(object):
|
|||
):
|
||||
return
|
||||
|
||||
# At this point we're committed to parsing the request as form data.
|
||||
self._data = self._request.POST
|
||||
self._files = self._request.FILES
|
||||
self._full_data = self._data.copy()
|
||||
self._full_data.update(self._files)
|
||||
# Reading the request body before directly accessing the POST attr will
|
||||
# ensure the request body is stored, making it accessible again later.
|
||||
# DRF uses multipart/form-data by default, which triggers an optimization
|
||||
# in the underlying django request. For more details:
|
||||
# https://github.com/django/django/blob/1.8.2/tests/requests/tests.py#L353-L372
|
||||
if api_settings.FORM_OVERRIDE_DO_PARSE:
|
||||
self._request.body
|
||||
data = self._request.POST
|
||||
else:
|
||||
self._data = self._request.POST
|
||||
self._files = self._request.FILES
|
||||
self._full_data = self._data.copy()
|
||||
self._full_data.update(self._files)
|
||||
data = self._data
|
||||
|
||||
# Method overloading - change the method and remove the param from the content.
|
||||
if (
|
||||
self._METHOD_PARAM and
|
||||
self._METHOD_PARAM in self._data
|
||||
self._METHOD_PARAM in data
|
||||
):
|
||||
self._method = self._data[self._METHOD_PARAM].upper()
|
||||
self._method = data[self._METHOD_PARAM].upper()
|
||||
|
||||
# Content overloading - modify the content type, and force re-parse.
|
||||
if (
|
||||
self._CONTENT_PARAM and
|
||||
self._CONTENTTYPE_PARAM and
|
||||
self._CONTENT_PARAM in self._data and
|
||||
self._CONTENTTYPE_PARAM in self._data
|
||||
self._CONTENT_PARAM in data and
|
||||
self._CONTENTTYPE_PARAM in data
|
||||
):
|
||||
self._content_type = self._data[self._CONTENTTYPE_PARAM]
|
||||
self._stream = six.BytesIO(self._data[self._CONTENT_PARAM].encode(self.parser_context['encoding']))
|
||||
self._data, self._files, self._full_data = (Empty, Empty, Empty)
|
||||
self._content_type = data[self._CONTENTTYPE_PARAM]
|
||||
self._stream = six.BytesIO(data[self._CONTENT_PARAM].encode(self.parser_context['encoding']))
|
||||
|
||||
def _parse(self):
|
||||
"""
|
||||
|
|
|
@ -94,6 +94,7 @@ DEFAULTS = {
|
|||
'TEST_REQUEST_DEFAULT_FORMAT': 'multipart',
|
||||
|
||||
# Browser enhancements
|
||||
'FORM_OVERRIDE_DO_PARSE': False,
|
||||
'FORM_METHOD_OVERRIDE': '_method',
|
||||
'FORM_CONTENT_OVERRIDE': '_content',
|
||||
'FORM_CONTENTTYPE_OVERRIDE': '_content_type',
|
||||
|
|
Loading…
Reference in New Issue
Block a user