在 DRF 的 abstractuser 中调用 create_superuser 和 create_user 函数
calling create_superuser and create_user function in abstractuser in DRF
我有 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 user 有什么区别吗?
如果您仔细检查 create_user_XYZ(...)
方法,您会发现所有这些方法都在创建 User
(或YourCustomModel
)个实例。这些方法按照预期很好地分开了。例如,create_superuser(...)
将创建一个超级用户,而 create_user()
将创建一个普通实例。
除此之外,在涉及到auth models时,我们需要设置密码,密码不应该存储在纯文本而不是它必须在保存到数据库之前进行哈希处理。所以,这些 create_XYZ
方法也为我们处理了一些额外的逻辑。
我有 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 user 有什么区别吗?
如果您仔细检查 create_user_XYZ(...)
方法,您会发现所有这些方法都在创建 User
(或YourCustomModel
)个实例。这些方法按照预期很好地分开了。例如,create_superuser(...)
将创建一个超级用户,而 create_user()
将创建一个普通实例。
除此之外,在涉及到auth models时,我们需要设置密码,密码不应该存储在纯文本而不是它必须在保存到数据库之前进行哈希处理。所以,这些 create_XYZ
方法也为我们处理了一些额外的逻辑。