Django authenticate函数验证问题

再用Django做CMS(内容关系系统)中需要注册用户登陆系统

在models中用户类继承了AbstractUser类

class NewUser(AbstractUser):  # 用户,继承的是AbstractUser    profile = models.CharField('profile', default='', max_length=256)  

    def __str__(self):
        return self.username  

继承AbstractUser这个类,我们需要在settings.py中申明默认的user类,我们在settings.py中加入一条申明:

AUTH_USER_MODEL = 'cms.NewUser'

(AUTH_USER_MODEL格式:'app_label.model_name')


在注册时,使用user = NewUser(username=username, password=password, email=email)创建新用户

登陆的时候,使用authenticate()函数进行验证账号密码,发现登陆时输入正确的账号密码,登陆失败

而用python manage.py createsuperuser创建的管理员是可以正常登陆的

后来查看数据库后发现,用户的密码是用明文保存的,而管理员的密码是加密保存的


后来发现必须使用object.create_user()函数来创建对象才能加密密码

user = NewUser.objects.create_user(username=username, password=password1, email=email)
此时再创建账号密码,即可登陆成功

查看数据库中的密码均为加密保存


你可能感兴趣的:(python,django,cms,登陆验证)