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 交通频道 作文范文 漂亮男人经典台词 一对情侣的分手日记。看完我哭了。。。 晚登敬亭山(七绝) 飘雪的冬天,江南韵(散文) 一次难忘的英语期中考试作文500字 描写秋景的好段 小学小考作文1500字:看,这群小学生眼中的崔永元 2015年三公经费自查报告 如果我变成了回忆 美国9岁男孩凯恩·蒙罗伊的创业创意 小学二年级语文集体备课工作计划 六月雪开的季节作文800字 重点项目调度会讲话 存金存爱 笼中月 优秀三好学生代表发言稿 美丽的祖国手抄报版面设计图 小学六年级作文1000字:只要努力,一切会更好! 修改之二 全球刮起大长今飓风韩剧拉动韩国经济 科学发展创先争优心得体会:创先争优重在实效 记得,我还爱你,丫头 过春节日记 欢声满校园作文800字 团委办公室2013年工作计划 当我跨进初中大门的时候 企业财务管理目标的理性选择 永远做那个事事乐观的人作文500字 付饭钱 走错放下,不再从来 一个故事没有结局 如果我是一名画家700字 在全县第二次生态移民工程推进会议上的讲话 女白领成为剩女为什么 应届本科毕业生医学求职信范文 公司财务年终工作总结范文 可爱的动物作文350字 是你牵着我的手 美丽的郑州作文400字 千手观音作文600字 2013年11月党员思想汇报:加强作风建设 我们就活在当下 冰川世纪之恐怖的袭击 《一只拖鞋的迷途》 我不想回避 广安白塔 我哭了,其实我很善良 关于秋天各种景色的句子 2012年妇产科住院医师个人工作总结 好想听听你的声音 践行八荣八耻荣辱观论文

Copyright © 2016 phpStudy |