一:目录

  1)简介及无CSRF时存在隐患

  2)csrf原理

  3)csrf 设置

  4)Form提交(CSRF)

  5)Ajax提交(CSRF)
    CSRF请求头 X-CSRFToken

二:csrf简介 

  csrf主要是为了防止跨站请求伪造(XSS攻击别人可以提交运行JS代码)

  django为用户实现防止跨站请求伪造的功能,通过中间件 django.middleware.csrf.CsrfViewMiddleware 来完成。

  而对于django中设置防跨站请求伪造功能有分为全局和局部。

  全局:

    中间件 django.middleware.csrf.CsrfViewMiddleware

  局部:

    •   @csrf_protect,为当前函数强制设置防跨站请求伪造功能,即便settings中没有设置全局中间件。
    •   @csrf_exempt,取消当前函数防跨站请求伪造功能,即便settings中设置了全局中间件。

  注:from django.views.decorators.csrf import csrf_exempt,csrf_protect

二:csrf原理

      客户端发请求,如果是第一次过来,比如GET,我不仅把数据数据你,还给一串加密串,只我自己能反解。

   你下一次过来提交数据的时候,你要带这串来,这样我才允许,不然允许提交数据。

   这个一般体现在那里?如果你往后台发POST请求,你把CSRF禁掉话,会报403名错误了。

    django做了一层防护,GET不会有影响,POST的时候会在来你发过来的请求你找那个随机字符串。

    但是我们没有这个字符串。所以禁止。

    我们可以在页面form请求加一
        {{csrf_token}}生成随机串 这个就是CSRF的token.这样显示是没有用的。

  在form里{%csrf_token%}后台才能拿到token 这是django csft原理

 比如:别人的网站写JS代码,但是提交了我们的网站,如果没有开启csrf他就直接提交过来了,并运行了代码,这是很危险的。

  如果开吂CSRF。别人的网站没有随机token.他就不能提交代码到我们的网站。

三:csrf设置  

  1. settings:
  2. 'django.middleware.csrf.CsrfViewMiddleware',
  3.  
  4. form表单
  5.  
  6. <form action="/login/" method="post">
  7. {% csrf_token %} <!--post提供token给后台-->
  8. <input type="text" name="username">
  9. <input type="text" name="password">
  10. <input type="checkbox" value="" name="rmb">免登录10
  11. <input type="submit" name="+">
  12. </form>

  # {% csrf_token %}不仅在页面中生成,在cookie中也有生成.如图所示

  

  

四:form提交数据

  上面的提交需要csft_token传入到后台。我们有两种方式提交。第一种:普通submit,;第二种ajax提交。ajax也要带token,这能提交数据到后台

  普通submit提交,只需要在form里设置

  1. {% csrf_token %}

  提交POST后页面和cookie效果,会生成token:

  1. <form action="/login/" method="post">
  2. <input type='hidden' name='csrfmiddlewaretoken' value='GGO5hq95CfY3PrbGU2wep1WOpbMZOYNJ02QunbqKQOmeh1ShXNC1IIiTbut1Yij2' />
  3. <input type="text" name="username">
  4. <input type="text" name="password">
  5. <input type="checkbox" value="" name="rmb">免登录10秒
  6. <input type="submit" name="+">
  7. </form>
  8. </body>
  9. </html>

  10.   浏览器cookie
  11. Request Cookies 212
  12. Hm_lpvt_407473d433e871de861cf818aa1405a1 1510386206 N/A N/A N/A 53
  13. Hm_lvt_407473d433e871de861cf818aa1405a1 1509847957,1509936833,1509966824,1510386206 N/A N/A N/A 85
  14. csrftoken 4MGKIn5K2p8K3hYkPKPagY0akHpjieqZo8I9O8mpgYwVvRFVSvVXzFmf606lsyWi N/A N/A N/A 74
  15. Response Cookies 139
  16. csrftoken 4MGKIn5K2p8K3hYkPKPagY0akHpjieqZo8I9O8mpgYwVvRFVSvVXzFmf606lsyWi / 364.0 days 139

五:ajax提交  

  1. AJAX只要把csrftoken拿过来,放在请求头发过去就行了
    djangotokenKEY是什么:X-CSRFtoke
  1.   from django.conf import settings
  2.  
  3. print(settings.CSRF_HEADER_NAME)===>HTTP_X_CSRFTOKEN(jdango会在前面加HTTP_)==>X-CSRFtoken(请求头不能加下划线)
  4.  
  5. django规范来写就是X-CSRFtoken

  ajax提交两种方法:

  1)在ajax里提交headers:{"X-CSRFtoken":csrftoken},但是如果提交ajax非常多的时候就不方便,可以设置全局提交。

  

  1. <script src="/static/jquery-1.12.4.js"></script>
  2. <script src="/static/jquery.cookie.js"></script>
  3. <script>
  4. $("#btn").click(
  5. function(){
  6. //获取token
  7. var csrftoken=$.cookie("csrftoken")
  8.  
  9. $.ajax({
  10. url:"/login/",
  11. type:"POST",
  12. //token放在请求头
  13. headers:{"X-CSRFtoken":csrftoken},
  14. data:{"username":"root","password":123},
  15. success:function(data){
  16.  
  17. }
  18.  
  19. })
  20. })
  21. </script>
  1.   2)全文提交
  1. #方式2
  2. <!DOCTYPE html>
  3. <html lang="en">
  4. <head>
  5. <meta charset="UTF-8">
  6. <title>Title</title>
  7. </head>
  8. <body>
  9.  
  10. <form action="/login/" method="post">
  11. {% csrf_token %}
  12. <input type="text" name="username">
  13. <input type="text" name="password">
  14. <input type="checkbox" value="" name="rmb">免登录10
  15. <input type="submit" name="+">
  16. <input id="btn" type="button" value="增加">
  17. </form>
  18. <script src="/static/jquery-1.12.4.js"></script>
  19. <script src="/static/jquery.cookie.js"></script>
  20. <script>
  21. $("#btn").click(
  22. function(){
  23. //这就是发ajax请求
  24. {# obj=XMLHttpRequest()#}
  25. {# obj.open()#}
  26. {# obj.send()#}
  27. //可以对整个页面所有的ajax请求做配置
  28. //方式2
  29. $.ajaxSetup({
  30. //表示在发送ajax请求之前执行,这是全局中配置,比如下面有好多个ajax 请求
  31. beforeSend:function(xhr,settings){
  32. //xhr表示XML HTTP requst对象,所有AJAZ操作
  33. xhr.setRequestHeader("X-CSRFtoken",$.cookie("csrftoken"))
  34. }
  35. })
  36. //获取token
  37. {# var csrftoken=$.cookie("csrftoken")#}
  38.  
  39. $.ajax({
  40. url:"/login/",
  41. type:"POST",
  42. //token放在请求头
  43. //方式1
  44. {# headers:{"X-CSRFtoken":$.cookie("csrftoken")#}
  45. data:{"username":"root","password":123},
  46. success:function(data){
  47.  
  48. }
  49.  
  50. })
  51. })
  52. </script>
  53. </body>
  54. </html>

  3)其他问题

  A)

  1. #现在是全局都加了token,如果有几个就不需要token验证,如何处理? 给不需要验证的请求加@csrf_exempt装饰器
  2. @csrf_protect,为当前函数强制设置防跨站请求伪造功能,即便settings中没有设置全局中间件。
  3. @csrf_exempt,取消当前函数防跨站请求伪造功能,即便settings中设置了全局中间件。
  4. 注:from django.views.decorators.csrf import csrf_exempt,csrf_protect

  B)GET是不需要提交token认证的,所以修改如下

  1. #上面POST和GET都是token验证,其实GET是不需要token的,如何处理?
  2. <!DOCTYPE html>
  3. <html>
  4. <head lang="en">
  5. <meta charset="UTF-8">
  6. <title></title>
  7. </head>
  8. <body>
  9. {% csrf_token %}
  10.  
  11. <input type="button" onclick="Do();" value="Do it"/>
  12.  
  13. <script src="/static/plugin/jquery/jquery-1.8.0.js"></script>
  14. <script src="/static/plugin/jquery/jquery.cookie.js"></script>
  15. <script type="text/javascript">
  16. var csrftoken = $.cookie('csrftoken');
  17.  
  18. function csrfSafeMethod(method) {
  19. // these HTTP methods do not require CSRF protection
  20. return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
  21. }
  22. $.ajaxSetup({
  23. beforeSend: function(xhr, settings) {
  24. if (!csrfSafeMethod(settings.type) && !this.crossDomain) {
  25. xhr.setRequestHeader("X-CSRFToken", csrftoken);
  26. }
  27. }
  28. });
  29. function Do(){
  30.  
  31. $.ajax({
  32. url:"/app01/test/",
  33. data:{id:1},
  34. type:'POST',
  35. success:function(data){
  36. console.log(data);
  37. }
  38. });
  39.  
  40. }
  41. </script>
  42. </body>
  43. </html>

  总结:

  1)csrf主要是在settings里面设置,这个设置是全局的,特别设置可以使用@csrf_protect装饰器,即使全局中没有开启csrf验证,也要求验证。@csrf_exempt装饰器,可以要求不需要验证

  2)在页面form设置{% csrf_token %}

  3) 普通提交,后台不需要做任务修改

  4)ajax提交,需要把token发送到后台,后台也不需要做任务修改

21)django-csrf(跨站请求伪造)的更多相关文章

  1. Python菜鸟之路:Django CSRF跨站请求伪造

    前言 CSRF,Cross-site request forgery跨站请求伪造,也被称为“One Click Attack”或者Session Riding,通常缩写为CSRF或者XSRF,是一种对 ...

  2. ajax向Django前后端提交请求和CSRF跨站请求伪造

    1.ajax登录示例 urls.py from django.conf.urls import url from django.contrib import admin from app01 impo ...

  3. python 全栈开发,Day87(ajax登录示例,CSRF跨站请求伪造,Django的中间件,自定义分页)

    一.ajax登录示例 新建项目login_ajax 修改urls.py,增加路径 from app01 import views urlpatterns = [ path('admin/', admi ...

  4. 第三百一十五节,Django框架,CSRF跨站请求伪造

    第三百一十五节,Django框架,CSRF跨站请求伪造  全局CSRF 如果要启用防止CSRF跨站请求伪造,就需要在中间件开启CSRF #中间件 MIDDLEWARE = [ 'django.midd ...

  5. Django中的CSRF(跨站请求伪造)

    Django中的CSRF(跨站请求伪造) Django CSRF  什么是CSFR 即跨站请求伪装,就是通常所说的钓鱼网站. 钓鱼网站的页面和正经网站的页面对浏览器来说有什么区别? (页面是怎么来的? ...

  6. Django框架 之 基于Ajax中csrf跨站请求伪造

    Django框架 之 基于Ajax中csrf跨站请求伪造 ajax中csrf跨站请求伪造 方式一 1 2 3 $.ajaxSetup({     data: {csrfmiddlewaretoken: ...

  7. 十三 Django框架,CSRF跨站请求伪造

     全局CSRF 如果要启用防止CSRF跨站请求伪造,就需要在中间件开启CSRF #中间件 MIDDLEWARE = [ 'django.middleware.security.SecurityMidd ...

  8. Web框架之Django_09 重要组件(Django中间件、csrf跨站请求伪造)

    摘要 Django中间件 csrf跨站请求伪造 一.Django中间件: 什么是中间件? 官方的说法:中间件是一个用来处理Django的请求和响应的框架级别的钩子.它是一个轻量.低级别的插件系统,用于 ...

  9. django上课笔记3-ORM补充-CSRF (跨站请求伪造)

    一.ORM补充 ORM操作三大难点: 正向操作反向操作连表 其它基本操作(包含F Q extra) 性能相关的操作 class UserInfo(models.Model): uid = models ...

  10. Web框架之Django重要组件(Django中间件、csrf跨站请求伪造)

    Web框架之Django_09 重要组件(Django中间件.csrf跨站请求伪造)   摘要 Django中间件 csrf跨站请求伪造 一.Django中间件: 什么是中间件? 官方的说法:中间件是 ...

随机推荐

  1. 使用js弹出div刷新时闪烁解决方法

    <div style="visibility: hidden"> //弹出div内容 </div>

  2. JS创建对象之动态原型模式

    动态原型模式把所有信息都封装在了构造函数中,而通过在构造函数中初始化原型(仅在必要的情况下),又保持了 同时使用构造函数和原型的优点:换句话说,可以通过检查某个应该存在的方法是否有效,来决定是否需要初 ...

  3. 七、文件IO——I/O处理方式和文件锁

    7.1 I/O 处理方式 7.1.1 I/O处理的五种模型 阻塞I/O模型 若所调用的 I/O 函数没有完成相关的功能就会使进程挂起,直到相关数据到达才会返回.如 终端.网络设备的访问. 非阻塞模型 ...

  4. STLINK V2安装使用详解

    1.      解压st-link_v2_usb driver.zip文件. 2.       运行解压后的st-link_v2_usbdriver.exe文件,安装STLINK V2驱动程序.安装路 ...

  5. Docker 空间大小设置 - 十

    一.容器启动 默认存储大小: 1.一种在启动项 docker.service 中配置. 2.在启动项配置调用的 docker-storage 配置文件中配置: 二.Docker 容器默认启动文件: / ...

  6. :target方法实现切换

    <!DOCTYPE HTML><html><head> <title>:target切换</title> <meta charset= ...

  7. JDK1.8HashMap源码解读

    package java.util; import sun.misc.SharedSecrets; import java.io.IOException; import java.io.Invalid ...

  8. Django REST framework 第四章 Authentication

    到目前为止,撰写的API没有任何限制关于谁能更新.删除snippet. 我们更想要一些高级行为来确保: 1.代码段总是跟创建者有关联 2.只要认证通过的用户才能创建 3.只有创建者有权限更新或者删除 ...

  9. shiro 启动异常

    原因是:LoginController中用到,自动注入,要配置在 /permission1110/config/spring/applicationContext-service.xml中配置bean ...

  10. 一次悲催的nginx转发白屏经历

    背景 公司还有一个学习平台,由于公网地址问题,所以想用nginx转发一下,首先后端地址访问时没有问题的,一切正常. 用nginx转发后,访问nginx代理地址悲催了,出现了白屏. 排查过程 首先贴出来 ...