If you're doing REST-based web service stuff ... you should ignore request.POST.
— Malcom Tredinnick, Django developers group
REST framework's Request
class extends the standard HttpRequest
, adding support for REST framework's flexible request parsing and request authentication.
REST framework's Request objects provide flexible request parsing that allows you to treat requests with JSON data or other media types in the same way that you would normally deal with form data.
request.data
returns the parsed content of the request body. This is similar to the standard request.POST
and request.FILES
attributes except that:
POST
, meaning that you can access the content of PUT
and PATCH
requests.For more details see the parsers documentation.
request.query_params
is a more correctly named synonym for request.GET
.
For clarity inside your code, we recommend using request.query_params
instead of the Django's standard request.GET
. Doing so will help keep your codebase more correct and obvious - any HTTP method type may include query parameters, not just GET
requests.
The APIView
class or @api_view
decorator will ensure that this property is automatically set to a list of Parser
instances, based on the parser_classes
set on the view or based on the DEFAULT_PARSER_CLASSES
setting.
You won't typically need to access this property.
Note: If a client sends malformed content, then accessing request.data
may raise a ParseError
. By default REST framework's APIView
class or @api_view
decorator will catch the error and return a 400 Bad Request
response.
If a client sends a request with a content-type that cannot be parsed then a UnsupportedMediaType
exception will be raised, which by default will be caught and return a 415 Unsupported Media Type
response.
The request exposes some properties that allow you to determine the result of the content negotiation stage. This allows you to implement behaviour such as selecting a different serialisation schemes for different media types.
The renderer instance that was selected by the content negotiation stage.
A string representing the media type that was accepted by the content negotiation stage.
REST framework provides flexible, per-request authentication, that gives you the ability to:
request.user
typically returns an instance of django.contrib.auth.models.User
, although the behavior depends on the authentication policy being used.
If the request is unauthenticated the default value of request.user
is an instance of django.contrib.auth.models.AnonymousUser
.
For more details see the authentication documentation.
request.auth
returns any additional authentication context. The exact behavior of request.auth
depends on the authentication policy being used, but it may typically be an instance of the token that the request was authenticated against.
If the request is unauthenticated, or if no additional context is present, the default value of request.auth
is None
.
For more details see the authentication documentation.
The APIView
class or @api_view
decorator will ensure that this property is automatically set to a list of Authentication
instances, based on the authentication_classes
set on the view or based on the DEFAULT_AUTHENTICATORS
setting.
You won't typically need to access this property.
Note: You may see a WrappedAttributeError
raised when calling the .user
or .auth
properties. These errors originate from an authenticator as a standard AttributeError
, however it's necessary that they be re-raised as a different exception type in order to prevent them from being suppressed by the outer property access. Python will not recognize that the AttributeError
originates from the authenticator and will instead assume that the request object does not have a .user
or .auth
property. The authenticator will need to be fixed.
REST framework supports a few browser enhancements such as browser-based PUT
, PATCH
and DELETE
forms.
request.method
returns the uppercased string representation of the request's HTTP method.
Browser-based PUT
, PATCH
and DELETE
forms are transparently supported.
For more information see the browser enhancements documentation.
request.content_type
, returns a string object representing the media type of the HTTP request's body, or an empty string if no media type was provided.
You won't typically need to directly access the request's content type, as you'll normally rely on REST framework's default request parsing behavior.
If you do need to access the content type of the request you should use the .content_type
property in preference to using request.META.get('HTTP_CONTENT_TYPE')
, as it provides transparent support for browser-based non-form content.
For more information see the browser enhancements documentation.
request.stream
returns a stream representing the content of the request body.
You won't typically need to directly access the request's content, as you'll normally rely on REST framework's default request parsing behavior.
As REST framework's Request
extends Django's HttpRequest
, all the other standard attributes and methods are also available. For example the request.META
and request.session
dictionaries are available as normal.
Note that due to implementation reasons the Request
class does not inherit from HttpRequest
class, but instead extends the class using composition.
Copyright © 2011–present Encode OSS Ltd.
Licensed under the BSD License.
https://www.django-rest-framework.org/api-guide/requests/