1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > django ajax请求 csrf验证失败

django ajax请求 csrf验证失败

时间:2022-10-14 16:04:00

相关推荐

django ajax请求 csrf验证失败

如何解决django ajax请求 csrf验证失败的问题:

原文链接:/questions/5100539/django-csrf-check-failing-with-an-ajax-post-request

大概意思是:django官方给出的方法都不起作用,

高手给了这样一段代码来设置请求头:

/*====================django ajax ======*/

$.ajaxSetup({

beforeSend: function(xhr, settings) {

function getCookie(name) {

var cookieValue = null;

if (document.cookie && document.cookie != '') {

var cookies = document.cookie.split(';');

for (var i = 0; i < cookies.length; i++) {

var cookie = jQuery.trim(cookies[i]);

// Does this cookie string begin with the name we want?

if (cookie.substring(0, name.length + 1) == (name + '=')) {

cookieValue = decodeURIComponent(cookie.substring(name.length + 1));

break;

}

}

}

return cookieValue;

}

if (!(/^http:.*/.test(settings.url) || /^https:.*/.test(settings.url))) {

// Only send the token to relative URLs i.e. locally.

xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken'));

}

}

});

/*===============================django ajax end===*/

这个js片段加入到模板,这个方法是起作用的,好使!

方法2:

下面代码添加到模板中

<script type="text/javascript">

$.ajaxSetup({headers: {"X-CSRFToken": '{{ csrf_token }}'}});

</script>

这两种方法是一个意思,就是设置请求头中X-CSRFToken为csrf_token的值

但是单独的js无法在渲染模板时获取{{ csrf_token }}这个模板变量,所以只能从cookie中取值了,就显得代码长了些.

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。