oco*_*tts 9 django jquery django-csrf
我怎样才能jquery.post()在Django中使用该方法?
这就是我想要做的:
var postdata={
'username':$('#login-email').val(),
'password':$('#login-password').val()
}
$.post('/login/',postdata)
Run Code Online (Sandbox Code Playgroud)
我如何在django中保护CSRF?有没有办法将CSRF令牌添加到帖子数据?
mpe*_*pen 34
是.我相信它存储在{{ csrf_token }}.所以,就这么做
var postdata={
'username':$('#login-email').val(),
'password':$('#login-password').val(),
'csrfmiddlewaretoken': '{{ csrf_token }}'
}
Run Code Online (Sandbox Code Playgroud)
您可能需要仔细检查名称,但这应该是正确的.
我通常会将带有此内容的文件引用到我希望能够发出AJAX请求的每个页面:
if (!$)
var $ = django.jQuery;
$('html').ajaxSend(function(event, 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 = $.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'));
}
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
12309 次 |
| 最近记录: |