使用 jQuery 的 ajax 或者 post 之前 加入这个 js 代码:http://www.ziqiangxuetang.com/media/django/csrf.js

  1. /*====================django ajax ======*/
  2. jQuery(document).ajaxSend(function(event, xhr, settings) {
  3. function getCookie(name) {
  4. var cookieValue = null;
  5. if (document.cookie && document.cookie != '') {
  6. var cookies = document.cookie.split(';');
  7. for (var i = 0; i < cookies.length; i++) {
  8. var cookie = jQuery.trim(cookies[i]);
  9. // Does this cookie string begin with the name we want?
  10. if (cookie.substring(0, name.length + 1) == (name + '=')) {
  11. cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
  12. break;
  13. }
  14. }
  15. }
  16. return cookieValue;
  17. }
  18. function sameOrigin(url) {
  19. // url could be relative or scheme relative or absolute
  20. var host = document.location.host; // host + port
  21. var protocol = document.location.protocol;
  22. var sr_origin = '//' + host;
  23. var origin = protocol + sr_origin;
  24. // Allow absolute or scheme relative URLs to same origin
  25. return (url == origin || url.slice(0, origin.length + 1) == origin + '/') ||
  26. (url == sr_origin || url.slice(0, sr_origin.length + 1) == sr_origin + '/') ||
  27. // or any other URL that isn't scheme relative or absolute i.e relative.
  28. !(/^(\/\/|http:|https:).*/.test(url));
  29. }
  30. function safeMethod(method) {
  31. return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
  32. }
  33.  
  34. if (!safeMethod(settings.type) && sameOrigin(settings.url)) {
  35. xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken'));
  36. }
  37. });
  38. /*===============================django ajax end===*/

  1.  

python学习-- Django Ajax CSRF 认证的更多相关文章

  1. 关于Django Ajax CSRF 认证

    CSRF(Cross-site request forgery跨站请求伪造,也被称为“one click attack”或者session riding,通常缩写为CSRF或者XSRF,是一种对网站的 ...

  2. Django:之传递数据给JS、Ajax和Ajax CSRF认证

    Django传递数据给JS 有时候我们想把一个list或者dict传递给javascript,处理后显示到网页上,比如要用js进行可视化到数据. 请注意:如果是不处理,直接显示在网页上,用Django ...

  3. 将Python的Django框架与认证系统整合的方法

    将Python的Django框架与认证系统整合的方法 这篇文章主要介绍了将Python的Django框架与认证系统整合的方法,包括指定认证后台和编写认证后台等内容,需要的朋友可以参考下 将Django ...

  4. Python学习---Django的基础学习

    django实现流程 Django学习框架:     #安装: pip3 install django          添加环境变量    #1  创建project       django-ad ...

  5. Python学习---Django拾遗180328

    Django之生命周期 前台发送URL请求到Django的中间件进行内容校验,完成校验后到达路由映射文件url.py,然后调用视图函数views.py里面的函数进行内容处理[ 1.操作数据库进行数据读 ...

  6. Python学习---django模板语法180122

    django模板语法[Template] 模版的组成:  HTML代码+逻辑控制代码  <h1> {{ user_name }} </h1> 逻辑控制代码的组成: 1.变量: ...

  7. Python学习---django重点之视图函数

    django重点之视图函数 http请求中产生两个核心对象: http请求:HttpRequest对象,由Django自己创建 http响应:HttpResponse对象,由开发自己创建,必须返回一个 ...

  8. Python学习---Django的基础操作180116

    Django创建数据库操作 django流程之model实例 settigs.py:更改Django2.0.1的配置,更新为之前的路径配置 'DIRS': [os.path.join(BASE_DIR ...

  9. Python学习---Django下的Sql性能的测试

    安装django-debug-tools Python学习---django-debug-tools安装 性能测试: settings.py INSTALLED_APPS = [ ... 'app01 ...

随机推荐

  1. VS找到了XXX的副本,但是当前源代码与XXX中内置的版本不同

    1.博客园有解决ASP.Net出现以上问题的方法: 删除ASP.Net临时文件夹内的dll文件. https://www.cnblogs.com/autumn/p/5261576.html 2.但我的 ...

  2. Payoneer个人账户注册申请教程

    1)照牛排于2013年末写的<免费申请Payoneer万事达预付卡+美国银行账号教程>非常详尽,网友纷纷转载,但生命在于折腾,Payoneer官网几经改版,自2015年3月推出无卡账户以来 ...

  3. cms-登陆

    先介绍下登陆的思路: 1.在登陆页面首先前端验证用户名和密码是否正确,如果验证通过,则ajax的方式向后台提交数据. 2.在controller层,将得到的用户名名和密码封装进shiro的token, ...

  4. react爬坑之路(一)--报错output.path不是绝对路径

    之前,一直在纠结是学习angular好,学习vue好,还是学习react好,网上一搜索,也是各种对比,各种互喷,看过之后更纠结.就跟小时候一样纠结长大了是上清华好,还是上北大好,最后证明我想多了.总之 ...

  5. Android SDK下载OpenMobile api

    在Android SDK Manager的Tools -> Manager Add-on sites... -> User Defined Sites中,添加以下地址: http://se ...

  6. 【转】CentOS 7.0 安装Redis 3.2.1详细过程和使用常见问题

    http://www.linuxidc.com/Linux/2016-09/135071.htm 环境:CentOS 7.0 Redis 3.2.1 Redis的安装与启动 这里我把Redis放在/h ...

  7. kernel

    http://sebastianraschka.com/Articles/2014_kernel_pca.html

  8. jquery的ajax请求

    加载页面内容,如果不加选择器,会加载整个页面内容 加选择器会获取选择器内容 例如: <script> //可以获取json格式的文件 $.ajax({ type:"get&quo ...

  9. 第26题:LeetCode572:Subtree of Another Tree另一个树的子树

    题目描述 给定两个非空二叉树 s 和 t,检验 s 中是否包含和 t 具有相同结构和节点值的子树.s 的一个子树包括 s 的一个节点和这个节点的所有子孙.s 也可以看做它自身的一棵子树. 示例 1: ...

  10. elasticsearch 7 安装

    elasticsearch 安装 操作系统:CentOS Linux release 7.4 elasticsearch:elasticsearch-7.1.1 es7+centos7 1.软件下载 ...