首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Django navigator.sendbeacon csrf保护

Django navigator.sendbeacon csrf保护
EN

Stack Overflow用户
提问于 2019-12-22 19:46:18
回答 1查看 285关注 0票数 3

我对navigator.sendBeacon('endpoint/', data)有个问题。我有一个错误:禁止(CSRF令牌丢失或不正确。)因为它通过POST方法传递数据。我知道我应该设置csrf令牌,但我不知道在这种情况下如何设置它,有人知道应该如何设置吗?我使用的是Django==2.2.6。

EN

回答 1

Stack Overflow用户

发布于 2020-11-18 22:29:31

您应该执行以下操作:

代码语言:javascript
复制
var data = new FormData();        
data.append('csrfmiddlewaretoken', '{{csrf_token}}');
navigator.sendBeacon('endpoint/',data)

如果是js文件,那么您应该在html中创建一个变量,如下所示

代码语言:javascript
复制
<script>
    var csrftoken = '{{ csrf_token }}';
</script>

然后,当您像这样追加时,可以使用它:

代码语言:javascript
复制
data.append('csrfmiddlewaretoken', csrftoken);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59443915

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档