CSRF令牌丢失或不正确
在这里是Django的初学者,我已经尝试了很长时间了。我的中间件类中确实有“ django.middleware.csrf.CsrfViewMiddleware”,并且我的帖子中确实有令牌。
这是我的代码,我在做什么错?
from django.contrib.auth.forms import UserCreationFormfrom django.shortcuts import render_to_response
from django.http import HttpResponseRedirect
from chartsey.authentication.forms import RegistrationForm
from django.template import RequestContext
from django.core.context_processors import csrf
def register(request):
    if request.method == 'POST':
        c = RequestContext(request.POST, {})
        form = RegistrationForm(c)
        if form.is_valid():
            new_user = form.save()
            return HttpResponseRedirect("/")
    else:
        form = RegistrationForm()
    return render_to_response("register.html",  {'form': form,  }, )
这是我的模板:
{% block content %}    <h1>Register</h1>
    <form action="" method="POST"> {% csrf_token %}
        {{ form.as_p }}
    <input type="submit" value="Submit">
    </form>
{% endblock %}
回答:
你应该使用自动使用的render快捷功能return render(request, 'template.html'),RequestContext
- 使用
renderhttps://docs.djangoproject.com/en/2.2/topics/http/shortcuts/ - 添加CSRF中间件https://docs.djangoproject.com/en/2.2/ref/csrf/
 - 使用
{% csrf_token %}模板标签 - 确认你看到正在生成CSRF令牌值,并在表单请求中提交了该值
 
以上是 CSRF令牌丢失或不正确 的全部内容, 来源链接: utcz.com/qa/419211.html

