【问题标题】:How to use $.post with django?如何在 django 中使用 $.post?
【发布时间】:2011-07-21 10:01:09
【问题描述】:

如何在 Django 中使用jquery.post() 方法?

这就是我想要做的:

         var postdata={
              'username':$('#login-email').val(), 
              'password':$('#login-password').val()
         }

         $.post('/login/',postdata)

我如何在 django 中进行 CSRF 保护?有没有办法将 CSRF 令牌添加到 post 数据中?

【问题讨论】:

  • 我想你真的是想问“如何在 Python 中提交 AJAX 请求”,对吧?除了 jquery 之外,任何其他语言或框架中都没有“jquery.Post()”方法。您要求的是等效操作,对吗?
  • @Mike 我相信他在问如何使用 jQuery 将数据发布到 Django,我将(再次)编辑标题以使其更清晰

标签: django jquery django-csrf


【解决方案1】:

是的。我相信它存储在{{ csrf_token }}。所以,做吧

     var postdata={
          'username':$('#login-email').val(), 
          'password':$('#login-password').val(),
          'csrfmiddlewaretoken': '{{ csrf_token }}'
     }

您可能需要仔细检查名称,但这应该是正确的。

【讨论】:

  • 它实际上是{% csrf_token %},否则这是迄今为止最好的解决方案。
  • 哎呀我的意思是{{ csrf_token }} 另一个变体是隐藏表单字段变体!很抱歉混淆了这个话题:)
  • 'csrfmiddlewaretoken': '{{ csrf_token }}' 在 Django-1.3 上为我工作
  • 我也是,在 1.3 上它似乎必须是 csrfmiddlewaretoken
【解决方案2】:

我通常将包含此内容的文件引用到我希望能够发出 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'));
    }
});

【讨论】:

    【解决方案3】:

    虽然您没有在示例中提供您的 html,但假设您使用的是 &lt;form&gt; 是否安全?如果是这样,请将您的 CSRF 令牌模板标签添加到您的表单并在您的表单上调用 .serialize()

    【讨论】:

      【解决方案4】:

      您可以使用的 Django has a CSRF module 中的 contrib 模块。

      关于您的问题如何发送POST,只要您正确映射了 URL,请求就会发送给它。您可以通过检查请求对象上的request.POST 来专门处理POST 请求。

      【讨论】:

      • 我专门讨论了 $.post 方法。我问这个问题的原因是我不想处理这么麻烦的脚本。
      猜你喜欢
      • 2018-02-17
      • 2021-08-22
      • 2016-09-17
      • 2021-12-26
      • 1970-01-01
      • 2020-08-30
      • 2011-07-15
      • 2021-05-16
      • 2023-04-06
      相关资源
      最近更新 更多