“CSRF验证失败.CSRF令牌丢失或不正确。” Django的

时间:2012-05-08 08:30:01

标签: python django token csrf verification

我正在尝试根据Django Classifieds App创建一个Django应用,但在尝试提交表单时遇到错误:CSRF verification failed. Request aborted. Reason given for failure: CSRF token missing or incorrect.

我的格式为{% csrf_token %}

<form method="post" action="{% url classifieds.views.create.checkout ad.pk %}">
 {% csrf_token %}
  <table>
   {{ form }}
     <tr>
     <th><label>Total:</label></th>
     <td><div id="total">Choose options above</div></td>
     </tr>
  </table>
</form>

我也在使用from django.template import RequestContext

我还在我的settings.py中的MIDDLEWARE_CLASSES中添加了'django.middleware.csrf.CsrfViewMiddleware',

正确提交表格还有什么其他方法可以解决?

该功能如下:

def checkout(request, adId):
   ad = get_object_or_404(Ad, pk=adId)
   if request.method == 'POST':
    form = CheckoutForm(request.POST)
    if form.is_valid():

 ...

  payment.save()

  if django_settings.DEBUG:
    paypal_form = PayPalPaymentsForm(initial=paypal_values).sandbox()
  else:
    paypal_form = PayPalPaymentsForm(initial=paypal_values).render()

  return render_to_response('classifieds/paypal.html', {'form': paypal_form}, context_instance=RequestContext(request))
else:
  form = CheckoutForm()

return render_to_response('classifieds/checkout.html', {'ad': ad, 'form': form}, context_instance=RequestContext(request))

感谢您的建议。

1 个答案:

答案 0 :(得分:3)

你使用了正确的RequestContext,我不确定问题是否存在,但你也可以检查一下。 how to use it

的第3步
  
      
  • 在相应的视图函数中,确保正在使用'django.core.context_processors.csrf'上下文处理器。通常,这可以通过以下两种方式之一完成:

         
        
    1. 使用RequestContext,它始终使用'django.core.context_processors.csrf'(无论您的TEMPLATE_CONTEXT_PROCESSORS设置如何)。如果您使用的是通用视图或contrib应用程序,则您已经被覆盖,因为这些应用程序始终使用RequestContext
    2.   
  •