0

我正在做一个简单的 django 应用程序,需要确保我的 csrftoken 设置正确,以便我可以发布回复。

当我在本地进行测试并查看我的 javascript 调试时,一切正常,并且 csrf 已正确附加。但是当我查看在 Heroku 中运行的完全相同的断点时,整个 getCookie 函数返回一个空白。仅供参考,我正在使用Django Docs中的标准 getCookie 函数:

// using jQuery
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;
}
var csrftoken = getCookie('csrftoken');

其他 jQuery 和 javascript 在页面上正常工作,但在这种情况下,document.cookie 是完全空的。

我已经从一堆不同的域(herokuapp.com、domain_name 等)中尝试过,但都一样。为什么 document.cookie 是空的?里面不应该有东西吗?

4

1 回答 1

0

显然,Django(出于未知原因)不喜欢提交 X Header,所以我分解并提出:

{% csrf_token %}

在我的模板顶部。并补充说:

'csrfmiddlewaretoken': $('csrfmiddlewaretoken').val()};

回传数据。丑陋,但它的工作。

于 2013-08-07T05:54:15.267 回答