扩展form.is_valid()

tae*_*esu 4 django

我正在学习Django,我偶然发现了一些我需要帮助的东西:

forms.py

class UserForm(forms.ModelForm):
    password1 = forms.CharField(widget=forms.PasswordInput())
    password2 = forms.CharField(widget=forms.PasswordInput())

    class Meta:
        model = User
        fields = ('username', 'email', 'password1','password2')

    def password_matched(self):
        if self.data['password1'] != self.data['password2']:
            self.errors['password'] = 'Passwords do not match'
            return False
        else:
            return True

    def is_valid(self):
        valid = super(UserForm,self).is_valid()
        password_matched = self.password_matched()
        if valid and password_matched:
            return True
        else:
            return False
Run Code Online (Sandbox Code Playgroud)

views.py

def register(request):
     #blah...
     user.set_password(user.password)
     # user.set_password(user.password1) doesn't work ! WHY!?
Run Code Online (Sandbox Code Playgroud)

所以基本上,我检查,如果pw1 == pw2,
检查后,我要设置用户的密码PASSWORD1.
我最初使用该行,user.set_password(user.password1)但它抱怨User对象没有password1,但它在我使用时有效password.

这是为什么?谢谢.

kar*_*ikr 8

理想情况下,您应该使用此clean方法,并且永远不要触及该is_valid方法.

像这样的东西:

def clean(self):
    cd = self.cleaned_data

    password1 = cd.get("password1")
    password2 = cd.get("password2")

    if password1 != password2:
        #Or you might want to tie this validation to the password1 field
        raise ValidationError("Passwords did not match")



    return cd
Run Code Online (Sandbox Code Playgroud)

现在,在意见中,

def register(request):
   #blah...
   form = UserForm(request.POST or None)
   if request.method == "POST":
       if form.is_valid(): #This would call the clean method for you
           user = User.objects.create(...)
           user.set_password(form.cleaned_data.get("password1"))
           user.save()
       else: #Form is invalid
           print form.errors #You have the error list here. 
Run Code Online (Sandbox Code Playgroud)