Ajax请求Django的csrftoken验证问题 [Forbidden (CSRF token missing or incorrect.)]

当我们使用ajax请求django服务器时,请求方式为post ,此时若不加csrftoken验证则会报错,例如我请求的路由为login,报错信息如下图:

解决办法如下所示:

<script>
    $("#btn").click(function () {
       var uname = $("#uname").val();
       var upwd = $("#upwd").val();
       var csrftoken = $('[name="csrfmiddlewaretoken"]').val(); //获取csrftoken
       $.ajax({
           url:"/login/",
           type:"post",
           data:{
                "uname":uname,
                "upwd":upwd,
                "csrfmiddlewaretoken":csrftoken  //上传至django服务器验证
               },
           success:function(data){
                $("#suc").html(data)
               }
           })
    });
</script>

上述脚本是使用ajax请求django服务器的方法,注意我在脚本中注释的两个地方

 var csrftoken = $('[name="csrfmiddlewaretoken"]').val();   此行代码为获取隐含的csrftoken

"csrfmiddlewaretoken":csrftoken  此行意为将csrftoken上传至服务器验证,注意此处的key值只能为--csrfmiddlewaretoken

最后一步就是在html代码中填写    {% csrf_token %}  验证,例如 

<body>

<input type="text" id="uname" placeholder="username">&nbsp;<span id="unamemsg"></span><br><br>
<input type="password" id="upwd" placeholder="password">&nbsp;<span id="upwdmsg"></span><br><br>
<button id="btn">提交</button>&nbsp;<span id="suc"></span>
{% csrf_token %}
</body>

这样就可以向服务器进行post请求了,总结要点:

  1. html中添加  {% csrf_token %}
  2. 脚本中获取 csrftoken 并上传至服务器验证

如有问题请留言讨论! 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

带鱼工作室

感谢您的支持!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值