【发布时间】:2014-01-15 02:10:13
【问题描述】:
我正在编写登录代码。当我手动编写表单时,我得到了它的工作。
以下代码有效:
views.py
def login_view(request):
if request.method == 'GET':
return render(request, 'app/login.htm')
if request.method == 'POST':
username = request.POST.get('username', '')
password = request.POST.get('password', '')
user = auth.authenticate(username=username, password=password)
if user is None:
return HttpResponseRedirect(reverse('error'))
if not user.is_active:
return HttpResponseRedirect(reverse('error'))
# Correct password, and the user is marked "active"
auth.login(request, user)
# Redirect to a success page.
return HttpResponseRedirect(reverse('home'))
模板:
<form method="post" action="{% url 'login' %}">
{% csrf_token %}
<p><label for="id_username">Username:</label> <input id="id_username" type="text" name="username" maxlength="30" /></p>
<p><label for="id_password">Password:</label> <input type="password" name="password" id="id_password" /></p>
<input type="submit" value="Log in" />
<input type="hidden" name="next" value="" />
</form>
太棒了!但现在我想用 Django 的表单做同样的事情。
下面的代码不起作用,因为我总是得到 is_valid() == False。
views.py:
def login_view(request):
if request.method == 'POST':
form = AuthenticationForm(request.POST)
print form.is_valid(), form.errors, type(form.errors)
if form.is_valid():
## some code....
return HttpResponseRedirect(reverse('home'))
else:
return HttpResponseRedirect(reverse('error'))
else:
form = AuthenticationForm()
return render(request, 'app/login.htm', {'form':form})
模板:
<form action="{% url 'login' %}" method="post">{% csrf_token %}
{{ form.as_p }}
<input type="submit" value="Submit" />
stackoverflow 上有很多人抱怨他们得到的 is_valid 总是假的。我已经阅读了所有这些帖子,据我所知,我没有犯任何这些错误。我发现了一个新错误:-)
编辑:我在代码中添加了打印。打开登录视图并提交时的输出是
[27/Dec/2013 14:01:35] "GET /app/login/ HTTP/1.1" 200 910
False <class 'django.forms.util.ErrorDict'>
[27/Dec/2013 14:01:38] "POST /app/login/ HTTP/1.1" 200 910
所以 is_valid() 为 False,但 form.errors 为空。
【问题讨论】:
-
出现错误时为什么要重定向?如果您不这样做,表单将与错误消息一起重新呈现,您将能够确切地看到表单无效的原因。完全删除第一个 else 子句。
-
我删除了你说的第一个else子句,提交后,表单只是再次重新渲染,清除。