[Django] #30059: DELETE request with payload makes subsequent request fail

13 views
Skip to first unread message

Django

unread,
Dec 23, 2018, 12:13:31 PM12/23/18
to django-...@googlegroups.com
#30059: DELETE request with payload makes subsequent request fail
-----------------------------------------+------------------------
Reporter: diurchenko | Owner: nobody
Type: Uncategorized | Status: new
Component: Uncategorized | Version: 2.1
Severity: Normal | Keywords:
Triage Stage: Unreviewed | Has patch: 0
Needs documentation: 0 | Needs tests: 0
Patch needs improvement: 0 | Easy pickings: 0
UI/UX: 0 |
-----------------------------------------+------------------------
In my application I use a frontend component FilePond
(https://pqina.nl/filepond/) to perform photo file uploads.
FilePond uses its own server protocol to manage temp files on the backend
and sends a photo ID as a payload for DELETE request. According to
RFC7231: "payload within a DELETE request message has no defined
semantics", but it isn't forbidden. Django development server can't
process a request that follows DELETE with payload as it regards the
payload to be a part of the next request's first line.
For example when photo ID is '0', next request is logged like this:
{{{
"0POST /accounts/profile/photo/ HTTP/1.1" 405 0
}}}
Quick and dirty fix for my View subclass is:
{{{
def delete(self, request):
# Drain the incoming buffer
request._stream.read()
...
return HttpResponse(status=204)
}}}
When incoming data are wholly consumed by DELETE handler, subsequent
requests work as expected.

Best regards,
Dmytro Yurchenko

--
Ticket URL: <https://code.djangoproject.com/ticket/30059>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.

Django

unread,
Dec 23, 2018, 1:48:27 PM12/23/18
to django-...@googlegroups.com
#30059: DELETE request with payload makes subsequent request fail
-------------------------------+--------------------------------------

Reporter: diurchenko | Owner: nobody
Type: Uncategorized | Status: new
Component: Uncategorized | Version: 2.1
Severity: Normal | Resolution:

Keywords: | Triage Stage: Unreviewed
Has patch: 0 | Needs documentation: 0
Needs tests: 0 | Patch needs improvement: 0
Easy pickings: 0 | UI/UX: 0
-------------------------------+--------------------------------------

Comment (by Simon Charette):

Are you using Django 2.1.4 by any chance? If that's the case then it's
possible you are affected by #30015 which will be fixed in 2.1.5 by
b514dc14f4e1c364341f5931b354e83ef15ee12d.

--
Ticket URL: <https://code.djangoproject.com/ticket/30059#comment:1>

Django

unread,
Dec 27, 2018, 9:09:30 AM12/27/18
to django-...@googlegroups.com
#30059: DELETE request with payload makes subsequent request fail
-------------------------------+--------------------------------------
Reporter: diurchenko | Owner: nobody
Type: Bug | Status: closed
Component: HTTP handling | Version: 2.1
Severity: Normal | Resolution: needsinfo

Keywords: | Triage Stage: Unreviewed
Has patch: 0 | Needs documentation: 0
Needs tests: 0 | Patch needs improvement: 0
Easy pickings: 0 | UI/UX: 0
-------------------------------+--------------------------------------
Changes (by Tim Graham):

* status: new => closed
* resolution: => needsinfo
* component: Uncategorized => HTTP handling
* type: Uncategorized => Bug


Comment:

In any case, I think we need a test or some some sample code reproduce the
issue.

--
Ticket URL: <https://code.djangoproject.com/ticket/30059#comment:2>

Django

unread,
Dec 28, 2018, 7:13:43 AM12/28/18
to django-...@googlegroups.com
#30059: DELETE request with payload makes subsequent request fail
----------------------------------+--------------------------------------
Reporter: Dmytro Yurchenko | Owner: nobody

Type: Bug | Status: closed
Component: HTTP handling | Version: 2.1
Severity: Normal | Resolution: duplicate

Keywords: | Triage Stage: Unreviewed
Has patch: 0 | Needs documentation: 0
Needs tests: 0 | Patch needs improvement: 0
Easy pickings: 0 | UI/UX: 0
----------------------------------+--------------------------------------
Changes (by Dmytro Yurchenko):

* resolution: needsinfo => duplicate


Comment:

Hello! It is Django 2.1.4. I have checked it with `master` branch and the
bug is no longer reproducible. I assume #30015 is indeed a more general
description (and fix) of the same issue. Thank you!

--
Ticket URL: <https://code.djangoproject.com/ticket/30059#comment:3>

Reply all
Reply to author
Forward
0 new messages