您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

django自定义用户模型密码未被哈希处理

5b51 2022/1/14 8:23:24 python 字数 4774 阅读 536 来源 www.jb51.cc/python

我有自己的自定义用户模型,也有自己的Manger. 楷模: class MyUser(AbstractBaseUser, PermissionsMixin): email = models.EmailField(max_length=255, unique=True) first_name = models.CharField(max_length=35) last_nam

概述

楷模:

class MyUser(AbstractBaseUser,PermissionsMixin):
    email = models.EmailField(max_length=255,unique=True)
    first_name = models.CharField(max_length=35)
    last_name = models.CharField(max_length=35)
    username = models.CharField(max_length=70,unique=True)
    date_of_birth = models.DateField()
    is_active = models.BooleanField(default=True)
    is_admin = models.BooleanField(default=False)

    @property
    def is_staff(self):
        return self.is_admin

    def get_full_name(self):
        return ('%s %s') % (self.first_name,self.last_name)

    def get_short_name(self):
        return self.username

    objects = MyUserManager()
    USERNAME_FIELD = 'email'
    required_FIELDS = ['first_name','last_name','username','date_of_birth']

经理:

class MyUserManager(BaseUserManager):
    def create_user(self,email,first_name,last_name,username,date_of_birth,password=None,**kwargs):
        if not email:
            raise ValueError('User must have an email address')

        user = self.model(
            email=self.normalize_email(email),first_name=first_name,last_name=last_name,username=username,date_of_birth=date_of_birth,**kwargs
        )
        user.set_password(self.cleaned_data["password"])
        user.save(using=self._db)
        return user

    def create_superuser(self,password,**kwargs):
        user = self.create_user(
            email,password=password,is_superuser=True,**kwargs
        )
        user.is_admin = True
        user.save(using=self._db)
        return user

创建新用户时没有任何错误,一切正常.但是当我尝试登录时我不能.所以我检查了用户的密码进行确认,密码显示为纯文本strongpassword,当更改管理表单以使用ReadOnlyPasswordHashField获取散列密码时,我在密码字段中出现错误,即使我在内部使用了set_password() create_user()函数.

Invalid password format or unkNown hashing algorithm

但是,如果我为该用户手动执行set_password(‘strongpassword’),则会对其进行哈希处理.你能帮我解决这个问题吗?谢谢.

如果您创建自定义用户,则需要定义正确处理密码的自定义模型表单和模型管理员.

否则,当通过Django管理员创建用户时,密码不会被散列.

用于创建自定义用户example in docs显示了如何创建模型表单和模型管理员.

总结

以上是编程之家为你收集整理的django自定义用户模型密码未被哈希处理全部内容,希望文章能够帮你解决django自定义用户模型密码未被哈希处理所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶