首頁 >web前端 >js教程 >django中使用jquery ajax post資料出現403錯誤的解決方法

django中使用jquery ajax post資料出現403錯誤的解決方法

亚连
亚连原創
2018-05-25 09:32:573763瀏覽

在django中,使用jquery ajax post數據,會出現403的錯誤,大家知道該如何解決嗎?下面由我給大家分享兩種解決辦法,需要的朋友可以參考下

#在django中,使用jquery ajax post數據,會出現403的錯誤

方法一:

如果用jQuery來處理aj​​ax的話,Django直接送了一段解決問題的程式碼。把它放在一個獨立的js檔案中,在html頁面中都引入即可。注意這個js檔案必須在jquery的js檔案引入之後,再引入即可

$(document).ajaxSend(function(event, xhr, settings) { 
  function getCookie(name) { 
    var cookieValue = null; 
    if (document.cookie && document.cookie != '') { 
      var cookies = document.cookie.split(';'); 
      for (var i = 0; i < cookies.length; i++) { 
        var cookie = jQuery.trim(cookies[i]); 
        // Does this cookie string begin with the name we want? 
        if (cookie.substring(0, name.length + 1) == (name + &#39;=&#39;)) { 
          cookieValue = decodeURIComponent(cookie.substring(name.length + 1)); 
          break; 
        } 
      } 
    } 
    return cookieValue; 
  } 
  function sameOrigin(url) { 
    // url could be relative or scheme relative or absolute 
    var host = document.location.host; // host + port 
    var protocol = document.location.protocol; 
    var sr_origin = &#39;//&#39; + host; 
    var origin = protocol + sr_origin; 
    // Allow absolute or scheme relative URLs to same origin 
    return (url == origin || url.slice(0, origin.length + 1) == origin + &#39;/&#39;) || 
      (url == sr_origin || url.slice(0, sr_origin.length + 1) == sr_origin + &#39;/&#39;) || 
      // or any other URL that isn&#39;t scheme relative or absolute i.e relative. 
      !(/^(\/\/|http:|https:).*/.test(url)); 
  } 
  function safeMethod(method) { 
    return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method)); 
  } 
  if (!safeMethod(settings.type) && sameOrigin(settings.url)) { 
    xhr.setRequestHeader("X-CSRFToken", getCookie(&#39;csrftoken&#39;)); 
  } 
});

方法二:

在處理post資料的view前加上@csrf_exempt裝飾符

例如

@csrf_exempt 
def profile_delte(request): 
  del_file=request.POST.get("delete_file",&#39;&#39;)

上面是我整理給大家的,希望今後會對大家有幫助。

相關文章:

詳解ajax jtemplate實作動態分頁

Ajax在請求過程中顯示進度的簡單實作

#JQuery Ajax動態產生Table表格

#

以上是django中使用jquery ajax post資料出現403錯誤的解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn