javascript - 在 Django 中使用 ajax POST 请求

标签 javascript jquery python ajax django

当我尝试在 Django 中使用 ajax 发送 POST 请求时遇到了一些问题。我已经在这里研究了一些主题,但仍然找不到解决它们的方法。

这是我的 javascript 代码,遵循 this solution :

$.ajax({
    url: '{% url home %}',
    data: {selected_folders: formData,
           csrfmiddlewaretoken: '{{ csrf_token }}'},
    dataType: "json",
    type: "POST",
});

我也试试 solution from Django

$("form").submit(function() {
    var csrftoken = $.cookie('csrftoken');
    $.ajax({
        url: '{% url home %}',
        data: {selected_folders: formData,
               csrfmiddlewaretoken: csrftoken},
        dataType: "json",
        type: "POST",
    });
});

这是我的view.py

def home(request):        
    if request.method == 'POST':
        Call_Other_Class()
    return render_to_response('home.html')

我的目标是将home.html的POST请求发送给自己,当home.html收到POST请求后,它会调用其他类做一些事情别的。我不确定在模板中放置 CSRF token 的位置以及我在 view.py 中的代码是否正确。

感谢您的阅读并解决我的问题。

编辑:

我将我的 javascript 代码编辑为:

<script type="text/javascript" charset="utf-8">
    $(document).ready(function() {
      var csrftoken = Cookies.get('csrftoken');
      function csrfSafeMethod(method) {
        return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
      }
      $.ajax({
        url: '{% url home %}',
        data: {selected_folders: formData},
        beforeSend: function(xhr, settings) {
          if (!csrfSafeMethod(settings.type) && !this.crossDomain) {
            xhr.setRequestHeader("X-CSRFToken", csrftoken);
          }
        },
        dataType: "json",
        type: "POST",
      });
    });
</script>

HTML:

<form>
  <ul>
    <li id='key1'></li>
    <li id='key2'></li>
  </ul>
</form>

还是不行。

最佳答案

对于 Js:

$("form").submit(function() {
   $.ajax({
       url: '{% url home %}',
       data: {selected_folders: formData,
           csrfmiddlewaretoken: $("[name = csrfmiddlewaretoken]"),
        dataType: "json",
        type: "POST",
    });
});

对于view.py:

def home(request):        
if request.method == 'POST' and request.is_ajax():
    Call_Other_Class()
return render_to_response('home.html')

关于javascript - 在 Django 中使用 ajax POST 请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32217741/

相关文章:

javascript - jQuery 下拉队列建立

javascript - UIWebView 将用户名和密码传递到表单中

javascript - 调用ajax函数,然后等待,然后再次调用另一个ajax函数

python - 在 OpenErp 7 中查询对象

python - 添加新列并计算比率

javascript - 在 Node.js 应用程序中使用 Stomp.js 自动重新连接

javascript - :-ms-input-placeholder is not working in IE9 in Windows 7 OS

javascript - 重定向用户的奇怪问题

jquery - 替换 <br> 后的文字

python - 如何更改我的 seaborn catplot 中的数字或行和列