Hello,
I have a django application where I want to make POST by clicking on <button>
which is not in <form>
The problem is that data sent to view function are not being sent properly.
Here is axios code:
axios({
method: 'post',
url: '/url/to/view'
data: {
obj_id: objectid,
content_type: contenttype,
like: !is_liked
},
xsrfCookieName: 'csrftoken',
xsrfHeaderName: 'X-CSRFToken',
headers: {'X-Requested-With': 'XMLHttpRequest',
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'},
}).then(function (response) {
console.log(response);
});
and here view code:
def my_view(request):
print request.POST
return HttpResponse('XX')
I cannot access request.POST data because the key is entire dict and value empty list:
<QueryDict: {u'{"obj_id":"182","content_type":"video","like":true}': [u'']}>
The problem is that objects are serialized to JSON by default while you need to send the data in the `application/x-www-form-urlencoded' format. The easiest solution is to use a library like qs:
var qs = require('qs');
axios.post('/foo', qs.stringify({ 'bar': 123 });
See this comment for details.
Hope this helps!
Another way is putting the values into the FormData object and post
I wrote small wrapper aroud axios which works fine with default Django >1.8 settings. Hope this helps somebody!
Most helpful comment
The problem is that objects are serialized to JSON by default while you need to send the data in the `application/x-www-form-urlencoded' format. The easiest solution is to use a library like qs:
See this comment for details.
Hope this helps!