我正在尝试根据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))
感谢您的建议。
答案 0 :(得分:3)
你使用了正确的RequestContext
,我不确定问题是否存在,但你也可以检查一下。 how to use it
在相应的视图函数中,确保正在使用'django.core.context_processors.csrf'上下文处理器。通常,这可以通过以下两种方式之一完成:
- 使用RequestContext,它始终使用'django.core.context_processors.csrf'(无论您的TEMPLATE_CONTEXT_PROCESSORS设置如何)。如果您使用的是通用视图或contrib应用程序,则您已经被覆盖,因为这些应用程序始终使用RequestContext