django中post提交表单时错误:CSRF verification failed. Request aborted

错误描述:

Help Reason given for failure: CSRF cookie not set.

最近用python建站时,每次我用到CSRF(Cross Site Request Forgeries)的时候,都会报错,总结下来错误提示一般会有这么几个:

1、CSRF cookie not set.
2、 CSRF token missing or incorrect.

其他错误大致都是这样,而导致错误的原因如下:

  1. CSRF的饼干未设置。
  2. 当Django的CSRF的机制还没有正确使用。 对于POST表单,您需要确保:*该视图功能使用模板RequestContext的,而不是断章取义。
  3. 在模板中,没有{%csrf_token%}标志
  4. setting.py中加入’django.middleware.csrf.CsrfViewMiddleware’;

注意:很多教程说要加入’django.middleware.csrf.CsrfResponseMiddleware’,,然而当你加入时,你就会发现报错;

解决办法如下:

  1. 表单里加上{% csrf_token %}

  2. 在Settings里的MIDDLEWARE_CLASSES增加配置:’django.middleware.csrf.CsrfViewMiddleware’;

  3. 在view文件中加入装饰器@csrf_exempt如下:

 from django.views.decorators.csrf import csrf_exempt

 @csrf_exempt 
 def contact(request):
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

逸尘️

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值