我正在学习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.
这是为什么?谢谢.
理想情况下,您应该使用此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)
| 归档时间: |
|
| 查看次数: |
3962 次 |
| 最近记录: |