django的csrf中间件

Django的csrf中间件

CSRF:跨站请求伪造Cross Site Request Forgery

CSRF的攻击流程

用户a 访问可信站点1做业务处理,此时浏览器会保存该网站的cookie,当用户a 访问不可信站点2时,如果站点2有指向站点1的链接时候,那么攻击就用可能发生

Eg:

1、包含站点1的链接,点击跳转

2、img 的src属性值是站点1的链接

3、Js加载,js里有跳转的动作

Django的解决方法

Django预防CSRF攻击的方法是在用户提交的表单中加入一个csrftoken的隐含值,这个值和服务器中保存的csrftoken的值相同

前后端的使用

后端

全局使用(禁用)

局部使用或禁用

from django.views.decorators.csrf import csrf_exempt(不使用CSRF验证), csrf_protect(使用CSRF校验)

前端

Form表单

Ajax 方式

<script src="//cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>

<script src="//cdn.bootcss.com/jquery-cookie/1.4.1/jquery.cookie.js"></script>

面试回答:

1 解释什么是CSRF

跨站请求伪造Cross Site Request Forgery

2什么是跨站请求伪造

用户a 访问可信站点1做业务处理,此时浏览器会保存该网站的cookie,当用户a 访问不可信站点2时,如果站点2有指向站点1的链接时候,那么攻击就用可能发生

3 Django是如何实现防止攻击

1 当浏览器和Django服务器交互的时候 Django服务器会生成一个随机的token(字符串) 然后把这个字符串保存到浏览器的从okie里,同时在页面添加隐藏的input标签 值就是csrf_token
2 以后再和服务器做post请求的时候 前端页面要带上csrf_token
3 服务器就会去校验前端传过来的csrf_token和服务器保存是不是一致 
    if 不一致:
        return 403 禁止访问
    else:
        一致的时候 正常相应
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django中间件Django框架中的一个重要概念,可以在请求和响应之间定义一些处理逻辑。Django提供了一些内置的中间件,比如Session中间件Csrf中间件等。除了内置的中间件,我们还可以自定义中间件来实现一些自定义的逻辑。 自定义中间件的步骤如下: 1. 创建一个Python文件,命名为middleware.py。 2. 定义一个中间件类,继承自django.middleware.BaseMiddleware类,并实现__init__、process_request、process_response方法。 - __init__方法:中间件初始化方法,可以接收Django的settings对象作为参数。 - process_request方法:处理请求前的逻辑,可以对请求进行处理或者拦截请求。 - process_response方法:处理响应后的逻辑,可以对响应进行处理或者拦截响应。 3. 在settings.py文件中配置中间件。 - 在MIDDLEWARE_CLASSES或者MIDDLEWARE中添加自定义中间件的路径。 下面是一个简单的示例: ```python # middleware.py class MyMiddleware: def __init__(self, get_response): self.get_response = get_response def process_request(self, request): # 处理请求前的逻辑 return None def process_response(self, request, response): # 处理响应后的逻辑 return response ``` ```python # settings.py MIDDLEWARE = [ # ... 'myproject.middleware.MyMiddleware', # ... ] ``` 以上示例中,我们定义了一个名为MyMiddleware的中间件类,并实现了process_request和process_response方法。在process_request方法中,我们可以对请求进行处理或者拦截请求;在process_response方法中,我们可以对响应进行处理或者拦截响应。最后,在settings.py文件中添加自定义中间件的路径即可。 需要注意的是,如果你的中间件是一个类而不是一个函数,那么你需要在类的构造函数中接收一个get_response参数,并将其保存在实例变量中。这里的get_response参数是一个可调用对象,它代表着整个Django请求-响应处理过程中的后续处理逻辑。在自定义中间件的process_request或process_response方法中,如果你想要继续执行后续的处理逻辑,就需要调用get_response方法。如果你不调用get_response方法,那么后续的处理逻辑就不会被执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值