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


Django是一个开放源代码的Web应用框架,由Python写成。采用了MVC的软件设计模式,即模型M,视图V和控制器C。它最初是被开发来用于管理劳伦斯出版集团旗下的一些以新闻内容为主的网站的,即是CMS(内容管理系统)软件。并于2005年7月在BSD许可证下发布。这套框架是以比利时的吉普赛爵士吉他手Django Reinhardt来命名的。

今天在尝试调用jQuery的ajax时发现一个问题,就是使用GET方法服务器可以正常返回,但是使用POST方法却不行。后来再测试表单方式的POST的方法也不行。只要POST必报HTTP 403错误!非常奇怪。。。   

在网上搜了一大堆资料以后原来是因为Django的Cross Site Request Forgery protection机制的问题。这个机制是为了保护不受csrf攻击。什么是crsf攻击,桃林博客中有一段较为浅显的讲解。解决方案Django的官网已经提供了http://docs.djangoproject.com/en/dev/ref/contrib/csrf/,根据说明修改后,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处理过程。也就是每次提交的时候,都触发这个过程,在提交的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方法就介绍完了,看完之后有何感想,欢迎小伙伴们分享自己的见解,祝大家心情愉快,工作顺利。



相关阅读:
win10搜索功能不能用怎么办 win10搜索功能不能用解决办法
ubuntu 命令行中文乱码问题的解决方法
浅析PHP绘图技术
详解php设置session(过期、失效、有效期)
几种设置表单元素中文本输入框不可编辑的方法总结
C++空类及没有成员变量的类的大小实例分析
Android高级开发之性能优化典范
windows无法启动WLAN AutoConfig错误代码1068的解决办法
java执行Linux命令的方法
老版本PHP转义Json里的特殊字符的函数
C#实现向多线程传参的三种方式实例分析
IIS和.NET(1.1/2.0)的安装顺序及错误解决方法
jQuery插件之Tocify动态节点目录菜单生成器附源码下载
PHP根据session与cookie用户登录状态操作类的代码
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 常识读后感 卡利的小屋 表示比较伤感的句子短句 学习郭明义事迹思想汇报 2015质量安全月活动总结 免费《记承天寺夜游》课件11.rar(15)k 社会的变化 20169月入党积极分子思想汇报 怎样做好民政工作 时空是简短的雨 《狼王梦》续写作文1600字 我所希望的未来世界 把快乐种在心里作文600字 转角,你已不再身边 医务工作者学习华益慰心得体会 树挪死,人挪活和穷则思变_励志文章 保护地球的倡议书 慎于言 学校运动会工作总结 绿色家园 环保先锋作文1500字 最是幸福那一刻作文 幽夜公主(1)作文1100字 社区党员党性分析材料 《冬至飞雪》诗歌 环保社新学期工作计划-学生会工作计划_学生会工作计划 为何落马高官都爱受贿 恕她太傻作文600字 五四青年节感悟 一种思绪 一些关于旅行的优美句子 饿出来的创业主意 读《滴水穿石的启示》作文600字 演讲稿:如果我是一名培训老师 读后感作文650字 燃气安全隐患整改方案 柳枝五首翻译 母亲节礼物 2013年12月大学生入党思想汇报:党课培训心得 大树和小树作文 泡泡国的公主作文700字 那些花儿,散落天涯作文450字 党课:为什么构建和谐社会要注重社会公平 多陪陪她 食品药品监督管理局工作规则(试行) 元宵节诗句,读古人的元宵节情怀 父亲,明年的清明,再见! 新疆中考满分作文500字_拥抱梦想 免费“意会”“言传”解难题——鉴赏文学作品的主题思想及其表现 超级搞笑方言小品剧本 :一万块 伤感心情短句精选 我爱上的不是你,我爱上的是我的爱情

Copyright © 2016 phpStudy |