1

我有一些 AJAX 每 5 秒轮询一次服务器:

var date = $('article').first().find('time').text();
console.log(date);

setInterval(function() {
    $.post('pollNewEntries', {'date':date}, newEntrySuccess)
}, 5000);

不幸的是,每次 AJAX 尝试轮询服务器时,我都会收到 403 错误,说明我发出了无效的 CSRF 请求。我之前在表单中使用过 AJAX,并在表单中包含了 CSRF 令牌,但我不确定如何使用像上面这样的无格式 AJAX 请求来做到这一点。

4

3 回答 3

2

这个问题的解决方案在 Django 文档中有描述:https ://docs.djangoproject.com/en/dev/ref/contrib/csrf/#ajax

将此代码添加到 js 的顶部:

$.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'));
        }
    }
});
于 2013-05-13T09:40:56.267 回答
0

您需要将csrf令牌与您的帖子数据一起传递:

var date = $('article').first().find('time').text();
console.log(date);

setInterval(function() {
    $.post('pollNewEntries', {'date':date, 'csrfmiddlewaretoken': '{{csrf_token}}'}, newEntrySuccess)
}, 5000);
于 2013-05-12T15:53:40.640 回答
0

只需在脚本中添加这些行。这是咖啡脚本中的一个示例:

### CSRF methods ###
csrfSafeMethod = (method) ->
  # these HTTP methods do not require CSRF protection
  return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method))

$.ajaxSetup(
  crossDomain: false
  beforeSend: (xhr, settings) ->
    if !csrfSafeMethod(settings.type)
      xhr.setRequestHeader("X-CSRFToken", $.cookie('csrftoken'))
)

阅读文档:CSRF

另一方面,正如user1427661向您建议的那样,使用 HTTP GET 方法而不是 POST 会更好,因为您只需要读取数据而无需写入任何内容。请参阅W3 文档

于 2013-05-12T16:30:30.163 回答