Csrf cookie 未使用 ajax 设置。多个浏览器出错
Posted
技术标签:
【中文标题】Csrf cookie 未使用 ajax 设置。多个浏览器出错【英文标题】:Csrf cookie not set with ajax. Error in several browsers 【发布时间】:2016-05-21 09:43:05 【问题描述】:希望你没事。
我对 Django CSRF cookie 有疑问。 我告诉你: 首先,我有一个自动将所有 CSRF cookie 标头 Ajax 放入的 JS 代码。直到一段时间它工作正常,但我注意到以下几点:
在 Firefox 和 Chrome 的隐身模式下,CSRF cookie 不起作用,发送一个空值。
在正常版本的 Chrome 中不发送任何 cookie,因此,没有 CSRF。
其次,我注意到另一个缺点:
在唯一一个 CSRF cookie 正确发送的浏览器中,正常模式下是 firefox。当我删除 cookie 并再次发出请求时,这会向我发送一个空值。
有人有办法解决这个问题吗?
然后我展示了将 cookie 设置为 CSRF 令牌的 JS 代码:
$(function()
//Obtenemos la información de csfrtoken que se almacena por cookies en el cliente
var csrftoken = getCookie('csrftoken');
//Agregamos en la configuración de la funcion $.ajax de Jquery lo siguiente:
$.ajaxSetup(
beforeSend: function(xhr, settings)
if (!csrfSafeMethod(settings.type) && sameOrigin(settings.url))
// Send the token to same-origin, relative URLs only.
// Send the token only if the method warrants CSRF protection
// Using the CSRFToken value acquired earlier
xhr.setRequestHeader("X-CSRFToken", csrftoken);
);
function sameOrigin(url)
// test that a given url is a same-origin URL
// url could be relative or scheme relative or absolute
var host = document.location.host; // host + port
var protocol = document.location.protocol;
var sr_origin = '//' + host;
var origin = protocol + sr_origin;
// Allow absolute or scheme relative URLs to same origin
return (url == origin || url.slice(0, origin.length + 1) == origin + '/') ||
(url == sr_origin || url.slice(0, sr_origin.length + 1) == sr_origin + '/') ||
!(/^(\/\/|http:|https:).*/.test(url));
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;
function csrfSafeMethod(method)
return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
);
根据额外信息告诉他们,并尝试这些其他问题中提出的解决方案,但未解决。
Django CSRF Cookie Not Set
no csrf token after ajax page load
Django - AJAX not working due to csrf token not working on windows
Django csrf in ajax POST (csrf cookie not set until csrf used)
【问题讨论】:
【参考方案1】:我真的是个大笨蛋。 解决方案很简单,完全使用我提出的问题的 JS 代码,只需添加模板标签:
% csrf_token %
这似乎很明显,但应该使用 cookie 作为 CSRF 进行编码。但是,当这不存在时,因为它们必须采取另一方面,在这种情况下是 CSRF 标签。
【讨论】:
以上是关于Csrf cookie 未使用 ajax 设置。多个浏览器出错的主要内容,如果未能解决你的问题,请参考以下文章
Django 1.9 AJAX 表单 CSRF 令牌 403 错误 - “未设置 CSRF cookie”
Django REST Framework CSRF 失败:未设置 CSRF cookie
禁止(未设置 CSRF cookie。):/paypal/ |姜戈