django - 在 DRF 中的 abstractuser 中调用 create_superuser 和 create_user 函数
问题描述
我有 customuser 模型,它从 Django 继承了 Abstratuser。但是,我不了解create_user 和create_superuser。例如,何时调用 create_user 函数以及何时调用 create_superuser 函数。
模型看起来像这样。
class CustomUserManager(BaseUserManager):
"""
Custom user model manager where email is the unique identifiers
for authentication instead of usernames.
"""
def create_user(self,first_name,last_name,email, password, **extra_fields):
"""
Create and save a User with the given email and password.
"""
if not email:
raise ValueError("The email must be set")
first_name = first_name.capitalize()
last_name = last_name.capitalize()
email = self.normalize_email(email)
user = self.model(
first_name=first_name, last_name=last_name, email=email, **extra_fields
)
#user = self.model(email=self.normalize_email(email), **extra_fields)
user.set_password(password)
user.save(using=self.db)
return user
def create_superuser(self, first_name,last_name,email, password, **extra_fields):
"""
Create and save a SuperUser with the given email and password.
"""
extra_fields.setdefault('is_staff', True)
extra_fields.setdefault('is_superuser', True)
extra_fields.setdefault('is_active', True)
if extra_fields.get('is_staff') is not True:
raise ValueError(_('Superuser must have is_staff=True.'))
if extra_fields.get('is_superuser') is not True:
raise ValueError(_('Superuser must have is_superuser=True.'))
return self.create_user(first_name,last_name,email, password, **extra_fields)
ROLE = (('admin','ADMIN'),('manager','MANAGER'),('staff','STAFF'))
class CustomUser(AbstractUser):
username = None
email = models.EmailField(unique=True)
first_name = models.CharField(max_length=255)
last_name = models.CharField(max_length=255)
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = []
role = models.CharField(max_length=15, choices=ROLE, default='staff')
objects = CustomUserManager()
def __str__(self):
return self.email
例如对于像联系人这样的其他常规模型,我们不在模型内部编写 create_contact 函数,而是创建一个 post api 并在视图和序列化程序中编写逻辑来创建一个联系人对象。但是为什么在 CustomUser 中我们必须显式地创建函数,尽管我们再次在寄存器视图中编写创建用户逻辑。此外,使用 AbstractUser 和 AbstractBase 用户有什么区别。
解决方案
如果您仔细检查这些create_user_XYZ(...)
方法,您会发现所有这些方法都在创建User
(或YourCustomModel
)实例。这些方法按预期很好地分开。例如,create_superuser(...)
将创建一个超级用户create_user()
并将创建一个普通实例。
除此之外,当涉及到auth models时,我们需要设置密码,密码不应该以纯文本形式存储,而必须在保存到 DB 之前进行哈希处理。因此,这些create_XYZ
方法还为我们处理了一些额外的逻辑。
推荐阅读
- dependencies - 将 Python3 环境迁移到虚拟 - 管理导入依赖项
- javascript - 需要使用以下代码进行说明
- android - 无法安装应用程序:INSTALL_FAILED_VERSION_DOWNGRADE
- javascript - 在 Vue JS 中创建卡片滑块
- reactjs - 使用 Spring Boot 和 ReactJS 的 IDP 发起的 SSO
- docker - 访问在 Linux 主机上的 docker 容器中运行的 PROPER IP 上的服务
- php - 如何将 PHP cURL 数据转换为数组?
- angular - 错误类型错误:无法读取未定义的属性“帖子”
- php - 在 PHP 调度系统槽中添加范围
- python - 如何使用嵌套字典遍历 url?