Django 1.11 - 密码重置

时间:2017-06-02 18:41:56

标签: django django-1.11

我遇到密码修改表单的问题。 我不想使用Django的密码重置功能。<​​/ p>

def view_password(request):
    if request.user.is_authenticated():
        if request.method == 'POST':
            form = ChangePasswordForm(request.POST)
            if form.is_valid():
                new_password = form.cleaned_data['new_password']
                confirm_password = form.cleaned_data['confirm_password']
                if new_password == confirm_password:
                    strengh = new_password[0].isalpha()
                    if all(c.isalpha() == strengh for c in new_password):
                        messages.add_message(request, messages.INFO, 'Le mot de passe doit contenir au moins 8 charactères lettres et chiffres.')
                    else:
                        update = User.objects.get(id=request.user.id)
                        update.set_password('new_password')
                        update.save()
                        messages.add_message(request, messages.INFO, 'Votre mot de passe a bien été changé.')
                else:
                    messages.add_message(request, messages.INFO, 'La confirmation du mot de passe est incorrect.')
            else:
                messages.add_message(request, messages.INFO, 'Une erreur est survenue pendant la modification.')
        else:
            form = ChangePasswordForm()
        return render(request, 'password.html', locals())
    else:
        from start.views import view_logon
        messages.add_message(request, messages.INFO, 'Vous devez être connecté pour accéder à cette page.')
        return redirect(view_logon)

表单效果很好,密码修改完成。但是,在查看数据库之后,似乎新密码没有得到很好的整理。实际上,当我尝试使用新密码或旧密码登录时,它不起作用。

感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

更改行

update.set_password('new_password')

要,

update.set_password(new_password)

您为每个用户设置了密码为“new_password”。这就是你无法登录的原因。

set_password将参数作为字符串并将哈希值作为密码。