Django+JQuery+Ajax+Post方案中的問題及解決

##遇到的問題前端

  • 請求發送後,服務端無響應
    Django對於POST請求會檢查請求來源,表單方式提交時:ajax

    • 在Form內添加 {% csrf_token %} 標籤;
    • request響應函數前,添加 @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

相關文章
相關標籤/搜索