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)
此时再创建账号密码,即可登陆成功

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


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值