django防止csrf跨域伪造攻击

Csrf跨域伪造攻击:使用当前浏览器还在生效状态的cookie对指定网站进行操作。最初针对的是银行网站的转账。
django防止csrf跨域伪造攻击_第1张图片

Django本身会对csrf进行校验,在django的1.4版本之前,csrf默认关闭,需要在settings当中手动开启,在1.4之后,默认开启
django防止csrf跨域伪造攻击_第2张图片

在django的任何post请求,都会在请求之初,给用户下发一下串用来校验身份的编码,并且每次请求不一样。
django防止csrf跨域伪造攻击_第3张图片
如果不加csrf_token校验,会发生csrf错误
django防止csrf跨域伪造攻击_第4张图片

使用django的csrf校验
1、返回post登陆页面的时候要用render方法,render方法和render_to_response方法的功能类似,但是会在第一个参数返回request,如果不返还,前端无法调用 {% csrf_token %}
在这里插入图片描述
2、在form表单内部的第一行,插入csrf校验,使用{% csrf_token %}
django防止csrf跨域伪造攻击_第5张图片
{% csrf_token %}标签实际上就是在前端的form表单当中生成了一个hidden隐藏域,name为csrfmiddlewaretoken,value是csrf校验的值
django防止csrf跨域伪造攻击_第6张图片
存入数据库的步骤和get请求类似

django防止csrf跨域伪造攻击_第7张图片

你可能感兴趣的:(Django)