CSRF令牌丢失或不正确

在这里是Django的初学者,我已经尝试了很长时间了。我的中间件类中确实有“ django.middleware.csrf.CsrfViewMiddleware”,并且我的帖子中确实有令牌。

这是我的代码,我在做什么错?

from django.contrib.auth.forms import UserCreationForm

from 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

  1. 使用renderhttps://docs.djangoproject.com/en/2.2/topics/http/shortcuts/
  2. 添加CSRF中间件https://docs.djangoproject.com/en/2.2/ref/csrf/
  3. 使用{% csrf_token %}模板标签
  4. 确认你看到正在生成CSRF令牌值,并在表单请求中提交了该值

以上是 CSRF令牌丢失或不正确 的全部内容, 来源链接: utcz.com/qa/419211.html

回到顶部