Django Rest frameworks: request.Post vs request.data?

前端 未结 2 1601
无人共我
无人共我 2021-02-12 23:01

The Django Rest Frameworks has this to say about POST, quoting a Django dev

Requests

If you\'re doing REST-based web service stuff ...

相关标签:
2条回答
  • 2021-02-12 23:37

    I think some users get redirected here when trying to get data from the POST body in vanilla Django (when they aren't using the Django REST framework). In case you're using a basic Django endpoint you use request.body to get data from the body of the request so long as it isn't form data that's being sent to the server (in that case use request.POST). This is different from the request.data attribute that is needed for accessing data with Django REST framework.

    from json import loads
    def login(request):
        json = loads(request.body)
        print(json['username']) # Prints the value associated with 
    

    loads(request.body) is needed because request.body returns a byte string. loads will convert that byte string into a dictionary.

    request.BODY, request.data, and request.DATA are all undefined for Django's default request object.

    https://docs.djangoproject.com/en/3.1/ref/request-response/

    Notice there is no .data attribute under HttpRequest which differs from the Django REST framework request.

    (This doesn't answer the original question but might help users that end up here who aren't using the REST framework)

    0 讨论(0)
  • 2021-02-12 23:54

    The docs cover this:

    request.data returns the parsed content of the request body. This is similar to the standard request.POST and request.FILES attributes except that:

    • It includes all parsed content, including file and non-file inputs.
    • It supports parsing the content of HTTP methods other than POST, meaning that you can access the content of PUT and PATCH requests.
    • It supports REST framework's flexible request parsing, rather than just supporting form data. For example you can handle incoming JSON data in the same way that you handle incoming form data.

    The last two are the important ones. By using request.data throughout instead of request.POST, you're supporting both JSON and Form-encoded inputs (or whatever set of parsers you have configured), and you'll be accepting request content on PUT and PATCH requests, as well as for POST.

    Is one more flexible?

    Yes. request.data is more flexible.

    0 讨论(0)
提交回复
热议问题