您需要做的是将AUTH_USER_MODEL 添加到自定义用户类路径的设置中,该类扩展了 AbstractBaseUser(更可定制的版本)或 AbstractUser。
从 django.db 导入模型
从 django.contrib.auth.models 导入(
BaseUserManager, AbstractBaseUser
)
MyUserManager 类(BaseUserManager):
def create_user(self, email, date_of_birth, password=None):
"""
使用给定的电子邮件创建并保存用户,日期
出生和密码。
"""
如果不是电子邮件:
raise ValueError('用户必须有一个电子邮件地址')
用户 = self.model(
email=MyUserManager.normalize_email(email),
date_of_birth=date_of_birth,
)
user.set_password(密码)
user.save(使用=self._db)
返回用户
def create_superuser(self, username, date_of_birth, 密码):
"""
使用给定的电子邮件创建并保存超级用户,日期
出生和密码。
"""
u = self.create_user(用户名,
密码=密码,
date_of_birth=date_of_birth
)
u.is_admin = True
u.save(使用=self._db)
还你
MyUser 类(AbstractBaseUser):
电子邮件 = 模型。电子邮件字段(
verbose_name='电子邮件地址',
最大长度=255
)
date_of_birth = models.DateField()
is_active = models.BooleanField(default=True)
is_admin = models.BooleanField(default=False)
对象 = MyUserManager()
USERNAME_FIELD = '电子邮件'
REQUIRED_FIELDS = ['date_of_birth']
def get_full_name(self):
# 用户由他们的电子邮件地址识别
返回self.email
def get_short_name(self):
# 用户由他们的电子邮件地址识别
返回self.email
def __unicode__(self):
返回self.email
def has_perm(self, perm, obj=None):
“用户有特定的权限吗?”
# 最简单的答案:是的,总是
返回真
def has_module_perms(self, app_label):
“用户是否有权查看应用程序`app_label`?”
# 最简单的答案:是的,总是
返回真
@财产
def is_staff(自我):
“用户是工作人员吗?”
# 最简单的答案:所有管理员都是员工
返回 self.is_admin