django js 处理POST请求时的csrf_token

本文详细介绍了在使用Ajax与Django进行交互时,遇到CSRF Token缺失或不正确的问题及解决方案。通过在模板中使用{% csrf_token %}

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

   在使用ajax进行参数传递时,django会提示 Forbidden (csrf token missing or incorrect) 

   这是因为在我们提交的时候没有提交csrfmiddlewaretoken 参数。

   解决方式如下:

   在你的templates中放入

{% csrf_token %} 

  这是为了在前端生成存储csrfmiddlewaretoken的input标签,以至于我们在提交参数的时候,获取这里面的值就可以了!

  其标签样式如下:

  

<input type="hidden" name="csrfmiddlewaretoken" value="cSiDMAU6Rz8VrvadeLnGkoNhv2DeS9Aydd17oPdjeq9sDMrfag364tLkzP9pRSiK">

 所以在之后的ajax 提交的时候,把这里面的参数弄出来,加入data中就可以了,例如:

$.ajax({
            url:"path/",
            type:"POST",
            data:{"name": name, "csrfmiddlewaretoken": csrf_token}, //csrf_token是你自己需要获取的值(从刚才的那个hidden的input)
            success:function (args) {
            }
        });

参考文章:Ajax请求中提交csrfToken | django中csrf的其他使用 | Django

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值