##遇到的問題前端
請求發送後,服務端無響應
Django對於POST請求會檢查請求來源,表單方式提交時:ajax
{% csrf_token %}
標籤;@csrf_exempt
;Jquery POST 方式提交時,在服務端添加了 @csrf_exempt ,在Django1.5版本後,沒法直接經過POST獲取參數,經過raw_data = request.body
獲取數據時,出現以下錯誤提示:json
Exception: You cannot access body after reading from request's data streamcookie
其實這個提示的意思是在獲取body數據前,數據流已經被讀過;問題就出在 @csrf_exempt 上,Django提早對request作了讀取驗證操做,所以問題就來了:Django服務端要接收POST請求,須要支持csrf_exempt,但添加這個前置後,又沒法獲取POST參數了。函數
解決辦法:不使用服務端的@csrf_exempt前置說明,前端添加csrftoken,讓服務端能夠接收到POST請求。code
$.ajaxSetup({ dataType: "json",
beforeSend: function(xhr, settings){
var csrftoken = $.cookie('csrftoken');
xhr.setRequestHeader("X-CSRFToken", csrftoken);
},
});orm
爲Ajax添加預處理,保證每次POST請求時,自動發送csrftoken,這樣就能夠在服務端正常處理POST數據了。csrf
生命在於折騰~~token