我整天都试图弄清楚这一点,但我真的看不出问题的根源。
我有一个Django AuthenticationForm
似乎正在以某种方式提交数据,但未得到验证。
forms.py:
class LoginForm(AuthenticationForm):
username = forms.CharField(widget=forms.TextInput(attrs={'name': 'username'}))
password = forms.CharField(widget=forms.PasswordInput(attrs={'name': 'password'}))
views.py:
def index(request):
template = 'myapp/login.html'
if request.method == "POST":
print request.POST #prints QueryDict with its data
reg = LoginForm(request.POST or None)
if reg.is_valid():
return HttpResponse('Success: Form is valid!')
else:
return HttpResponse('Error: Form not valid')
loginform = LoginForm()
context = {'loginform':loginform}
return render(request, template, context)
HTML:
<form method="post" action=".">
{% csrf_token %}
<h2>Sign in</h2>
<p class="text-danger">{{loginform.errors}}</p>
{{ loginform.as_p }}
<button name = "signin" type="submit" value="0">Sign in</button>
</form>
我views.py中的
print request.POST
打印QueryDict:{u'用户名':[u'yax'],u'csrfmiddlewaretoken':[u'r8y1PaVNjxNWypdzPMaFe1ZL7IkE1O7Hw0yRPQTSipW36z1g7X3vPS5qMMX56byj'],u'password':[u'sdfdsfsddfs']
,u'signin':[u'0']},但
reg.is_valid()
始终返回false
。编辑:
我也曾尝试打印出
reg.errors
,但它没有打印出任何东西。 最佳答案
尝试进行以下更改:
reg = LoginForm(data=request.POST)
AuthenticationForm
稍有不同,因为它需要data
参数。还要注意,您应该使用实际有效的用户名和密码组合(与现有用户相对应)对其进行测试,因为
AuthenticationForm
也会对此进行检查。