Реальное решение
Хорошо, мне удалось отследить проблему. Он лежит в коде Javascript (как я предложил ниже).
Что вам нужно, это:
$.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'));
}
}
});
вместо кода, опубликованного в официальных документах:
https://docs.djangoproject.com/en/2.2/ref/csrf/
Рабочий код, полученный из этой записи Django: http://www.djangoproject.com/weblog/2011/feb/08/security/
Итак, общее решение: «использовать обработчик ajaxSetup вместо обработчика ajaxSend». Я не знаю, почему это работает. Но у меня это работает :)
Предыдущий пост (без ответа)
На самом деле я испытываю ту же проблему.
Это происходит после обновления до Django 1.2.5 - в Django 1.2.4 не было ошибок при запросах AJAX POST (AJAX не был защищен каким-либо образом, но работал нормально).
Так же, как OP, я попробовал фрагмент JavaScript, размещенный в документации Django. Я использую jQuery 1.5. Я также использую промежуточное программное обеспечение "django.middleware.csrf.CsrfViewMiddleware".
Я пытался следовать коду промежуточного программного обеспечения, и я знаю, что он не работает на этом:
request_csrf_token = request.META.get('HTTP_X_CSRFTOKEN', '')
, а затем
if request_csrf_token != csrf_token:
return self._reject(request, REASON_BAD_TOKEN)
это "если" верно, потому что "request_csrf_token" пусто.
В основном это означает, что заголовок НЕ установлен. Так что с этой строкой JS что-то не так:
xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken'));
Я надеюсь, что предоставленные данные помогут нам решить проблему:)