我整天都试图弄清楚这一点,但我真的看不出问题的根源。

我有一个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'r8y1PaVNjxNWypdzP
MaFe1ZL7IkE1O7Hw0yRPQTSipW36z1g7X3vPS5qMMX56byj'],u'password':[u'sdfdsfsddfs']
,u'signin':[u'0']},但reg.is_valid()始终返回false

编辑:

我也曾尝试打印出reg.errors,但它没有打印出任何东西。

最佳答案

尝试进行以下更改:

reg = LoginForm(data=request.POST)


AuthenticationForm稍有不同,因为它需要data参数。

还要注意,您应该使用实际有效的用户名和密码组合(与现有用户相对应)对其进行测试,因为AuthenticationForm也会对此进行检查。

09-25 20:55