3 种具有不同登录系统的用户类型。
- 学生:使用唯一的 student_id 和密码登录。
- SchoolAdmin:使用电子邮件和密码登录。
- 开发人员(团队):使用电子邮件和密码登录,并能够在管理面板中登录。
这是我的基本用户
class BaseUSER(AbstractBaseUser):
email = models.EmailField(unique=True)
first_name = models.CharField(max_length=50, null=True, blank=True)
last_name = models.CharField(max_length=50, null=True, blank=True)
USERNAME_FIELD = 'email'
这是我的第一个用户,学生
class StudentUser(BaseUSER):
student_id = models.CharField(primary_key=True,max_length=10)
address = models.CharField(max_length=500, blank=True)
city = models.CharField(max_length=50,blank=True, null=True)
state = models.CharField(max_length=50, blank=True, null=True)
pincode = models.CharField(max_length=6,blank=True, null=True)
email_id = models.EmailField(blank=True)
phone_number = models.CharField(max_length=10, blank=True, null=True)
mother_phone = models.CharField(max_length=10, blank=True, null=True)
father_phone = models.CharField(max_length=10, blank=True, null=True)
standard = models.CharField(max_length=2,blank=True, null=True)
# bus_transport = models.ForeignKey(Bus,blank=True,null=True)
USERNAME_FIELD = 'student_id'
这是我的用户 2 SchoolAdmin
class SchoolAdmin(BaseUSER):
school = models.ForeignKey(School,blank=True,null=True)
objects = NewUserManager()
USERNAME_FIELD = 'email'
这是我的用户号。3 开发团队(需要访问管理面板)
class team(BaseUSER):
pin_level = models.CharField(max_length=10)
def get_full_name(self):
return self.first_name
我为每个人创建了不同的用户管理器
学校管理员用户管理器
class NewUserManager(BaseUserManager):
use_in_migrations = True
def _create_user(self, email, password, **extra_fields):
"""
Creates and saves a User with the given email and password.
"""
if not email:
raise ValueError('The given email must be set')
email = self.normalize_email(email)
user = self.model(email=email, **extra_fields)
user.set_password(password)
user.save(using=self._db)
return user
def create_user(self, email, password=None, **extra_fields):
extra_fields.setdefault('is_superuser', False)
return self._create_user(email, password, **extra_fields)
开发团队的用户管理器:
class SuperManager(BaseUserManager):
use_in_migrations = True
def get_by_natural_key(self, email):
return self.get(**{self.model.USERNAME_FIELD: email})
def _create_user(self, email, password, **extra_fields):
"""
Creates and saves a User with the given email and password.
"""
if not email:
raise ValueError('The given email must be set')
email = self.normalize_email(email)
user = self.model(email=email, **extra_fields)
user.set_password(password)
user.save(using=self._db)
user.is_admin = True
return user
def create_user(self, email, password=None, **extra_fields):
extra_fields.setdefault('is_superuser', False)
return self._create_user(email, password, **extra_fields)
def create_superuser(self, email, password, **extra_fields):
extra_fields.setdefault('is_superuser', True)
if extra_fields.get('is_superuser') is not True:
raise ValueError('Superuser must have is_superuser=True.')
return self._create_user(email, password, **extra_fields)
我还为电子邮件登录创建了一个身份验证后端
如果我在哪里错了,请告诉我,我需要做什么以及我应该采取什么进一步的方法,因为我在这里感到震惊,
我想为管理面板实现登录,并且应该能够登录的用户来自类型 3 或团队。
提前致谢。