如何修复CSRF验证错误?

时间:2012-06-06 14:00:39

标签: python django templates csrf

我收到错误,“CSRF令牌丢失或不正确”,但我相信我已在模板中包含正确的标签。以下是显示此错误的视图和模板:

def contact(request):
    if request.method == 'POST':
        form = ContactForm(request.POST)
        if form.is_valid():
            cd = form.cleaned_data
            return HttpResponseRedirect('/contact/thanks/')
    else:
        form = ContactForm()
    return render_to_response('reserve/templates/contact_form.html',{'form': form})

模板:

<html>
<head>
    <title>Contact us</title>
</head>
<body>
    <h1>Contact us</h1>

    {% if form.errors %}
        <p style="color: red;">
            Please correct the error{{ form.errors|pluralize }} below.
        </p>
    {% endif %}

    <form action="" method="post">
    {% csrf_token %}
        <table>
            {{ form.as_p }}
        </table>
        <input type="submit" value="Submit">
    </form>
</body>
</html>

2 个答案:

答案 0 :(得分:2)

注意the instructions的第3项。快速执行此操作的方法是将render_to_response来电替换为render(request, 'reserve/templates/contact_form.html',{'form': form})(通过from django.shortcuts import render导入)。

答案 1 :(得分:0)

您应该将上下文实例传递给render_to_response

from django.template import RequestContext

return render_to_response('reserve/templates/contact_form.html', context_instance=RequestContext(request,{'form': form}))