主頁 > 知識庫 > Django框架如何使用ajax的post方法

Django框架如何使用ajax的post方法

熱門標簽:上海浦東百度地圖標注中心注冊 科智聯(lián)智能電銷機器人 目標三維地圖標注 青海醫(yī)療智能外呼系統(tǒng)怎么樣 外呼系統(tǒng)獲取客戶手機號 老虎郵局地圖標注點 徐州電銷卡外呼系統(tǒng)供應商 百靈鳥 襄陽外呼系統(tǒng)接口

Django是一個開放源代碼的Web應用框架,由Python寫成。采用了MVC的軟件設計模式,即模型M,視圖V和控制器C。它最初是被開發(fā)來用于管理勞倫斯出版集團旗下的一些以新聞內容為主的網(wǎng)站的,即是CMS(內容管理系統(tǒng))軟件。并于2005年7月在BSD許可證下發(fā)布。這套框架是以比利時的吉普賽爵士吉他手Django Reinhardt來命名的。

今天在嘗試調用jQuery的ajax時發(fā)現(xiàn)一個問題,就是使用GET方法服務器可以正常返回,但是使用POST方法卻不行。后來再測試表單方式的POST的方法也不行。只要POST必報HTTP 403錯誤!非常奇怪。。。   

在網(wǎng)上搜了一大堆資料以后原來是因為Django的Cross Site Request Forgery protection機制的問題。這個機制是為了保護不受csrf攻擊。什么是crsf攻擊,桃林博客中有一段較為淺顯的講解。解決方案Django的官網(wǎng)已經提供了http://docs.djangoproject.com/en/dev/ref/contrib/csrf/,根據(jù)說明修改后,ajax可以順利Post了。

具體辦法是,首先解決表單的POST。在settings.py文件中找到 MIDDLEWARE_CLASSES,在其中加入一個中間件:'django.middleware.csrf.CsrfViewMiddleware' ,修改后的代碼如下:

Python代碼

MIDDLEWARE_CLASSES = ( 
 'django.middleware.common.CommonMiddleware', 
 'django.contrib.sessions.middleware.SessionMiddleware', 
 'django.middleware.csrf.CsrfViewMiddleware', 
 'django.contrib.auth.middleware.AuthenticationMiddleware', 
 'django.contrib.messages.middleware.MessageMiddleware', 
 'django.middleware.csrf.CsrfResponseMiddleware', #加入這個中間件 
) 

     經過這番修改,可以解決表單方式的POST提交HTTP 403問題了。ajax的Post提交僅這樣改還不行。還需要鉤上一個每次提交時的cookie處理過程。也就是每次提交的時候,都觸發(fā)這個過程,在提交的http頭上加入csrf token。不過還好,如果你是用jQuery來處理ajax的話,Django直接送了一段解決問題的代碼。把它放在一個獨立的js文件中,在html頁面中都引入即可。注意這個js文件必須在jquery的js文件引入之后,再引入。代碼我直接復制過來了,如下:

Js代碼

$('html').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 + '=')) { 
     cookieValue = decodeURIComponent(cookie.substring(name.length + 1)); 
     break; 
    } 
   } 
  } 
  return cookieValue; 
 } 
 if (!(/^http:.*/.test(settings.url) || /^https:.*/.test(settings.url))) { 
  // Only send the token to relative URLs i.e. locally. 
  xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken')); 
 } 
}); 

 經過這番折騰,算是可以正常用ajax與Django通信了。

Django中ajax的使用

 前端的ajax代碼如下所示:

$.ajax({
 type:'GET',
 url:'/store/ds_mgmt_wx/ajax_handle',
 dataType:'html',
 success:function(data)
  {
   alert(data);
  },
 error:function(data)
 {
  alert(data); 
 }
});

后端的相應代碼的返回方法如下:

if act_job == 'ajax_handle':
  return HttpResponse('ajax_handle')

關于Django框架如何使用ajax的post方法就介紹完了,看完之后有何感想,歡迎小伙伴們分享自己的見解,祝大家心情愉快,工作順利。

您可能感興趣的文章:
  • django中使用jquery ajax post數(shù)據(jù)出現(xiàn)403錯誤的解決辦法(兩種方法)
  • django使用ajax post數(shù)據(jù)出現(xiàn)403錯誤如何解決
  • Django中ajax發(fā)送post請求 報403錯誤CSRF驗證失敗解決方案
  • django ajax發(fā)送post請求的兩種方法
  • django獲取ajax的post復雜對象的實現(xiàn)方法
  • django學習之ajax post傳參的2種格式實例

標簽:商洛 荊州 紅河 揭陽 股票 咸寧 辛集 佛山

巨人網(wǎng)絡通訊聲明:本文標題《Django框架如何使用ajax的post方法》,本文關鍵詞  Django,框架,如何,使用,ajax,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Django框架如何使用ajax的post方法》相關的同類信息!
  • 本頁收集關于Django框架如何使用ajax的post方法的相關信息資訊供網(wǎng)民參考!
  • 推薦文章