django中csrftoken跨站请求伪造的几种方式

Posted maydaytime

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了django中csrftoken跨站请求伪造的几种方式相关的知识,希望对你有一定的参考价值。

1.介绍

我们之前从前端给后端发送数据的时候,一直都是把setting中中间件里的的csrftoken这条给注释掉,其实这个主要起了一个对保护作用,以免恶意性数据的攻击。但是这样直接注释掉并不是理智型的选择,这里我们介绍以下几种方式来解决这个问题。

  csrf原理:先发送get请求,在用户浏览器上藏一段随机字符串,发送post请求时,浏览器自动携带该字符串来进行识别

2.方式一

在前端中添加{% csrf_token %},前端ajax发送的data数据中加上:

csrfmiddlewaretoken: $("[name=‘csrfmiddlewaretoken‘]").val()

3.方式二

在ajax中添加X-CSRFToken的请求头,必须从cookie中取csrftoken的值

$(‘#login‘).click(function () {
        $.ajax(
            {
                url:{% url ‘login‘ %},
                type: ‘post‘,
                headers:{ "X-CSRFToken":$.cookie(‘csrftoken‘) },
                data: {
                    user: $(‘[name="user"]‘).val(),
                    pwd: $(‘[name="pwd"]‘).val()
                },
                success: function (data) {
                    data = JSON.parse(data);
                    if (data.status) {
                        window.location = data.url
                    }
                    else {
                        alert(‘登陆错误‘)
                    }
                }
            }
        )
    })

4.方式三

使用$.ajaxSetup()给全局的ajax添加默认参数

$.ajaxSetup({
        headers: {"X-CSRFToken": $.cookie(‘csrftoken‘)},
    });

5.方式四

在需要设置cookie的视图上加装饰器 ensure_csrf_cookie()

from django.views.decorators.csrf import ensure_csrf_cookie

@ensure_csrf_cookie
def server(request):

    return render(request, ‘server.html‘)

 

以上是关于django中csrftoken跨站请求伪造的几种方式的主要内容,如果未能解决你的问题,请参考以下文章

Django--CSRF 跨站请求伪造

Django CSRF跨站请求伪造

Django网络安全跨站点请求伪造保护,CSRF如何正确使用

跨站请求伪造

Django之cfrs跨站请求伪造和xfs攻击

python之路--web--2--Django-6-跨站请求伪造