首先,您无法为项目创建多个身份验证用户群.所以你必须使用提供的Django用户身份验证,并将其分配给多种类型的用户. Django用户在注册时需要提供一些默认值(尝试在Django Admin中创建一个用户).您可以做的是创建一个名为“CustomUser”的模型,并继承自AbstractUser.这将使您的“CustomUser”模型成为项目用户的默认模型.因为您继承自AbstractUser,因此“CustomUser”模型将具有原始用户模型中的每个字段,然后可以自行添加一些字段.您还需要在项目的settings.py文件中指定原始用户模型不是您的默认身份验证模型,它是将用于身份验证的新“CustomUser”模型.看看下面的代码是否有帮助.
from django.db import models
from django.contrib.auth.models import AbstractUser
class CustomUser(AbstractUser):
type_choices = (
('SU', 'Super User'),
('A', 'User Type A'),
('B', 'User Type B'),
('C', 'User Type C'),
)
user_type = models.CharField(max_length=2,
choices=type_choices,
default='C')
class UserDetails(model.Model):
type = models.OneToOneField('CustomUser')
extra_info = models.CharField(max_length=200)
在上面的代码中,您创建了CustomUser模型,用户可以在其中提供Django中默认的用户名,密码等基本信息.然后,您可以选择其用户类型,并将您的附加信息保存在UserDetails模型上,该模型与您的新身份验证模型也具有ForeignKey关系.最后你需要做的是在settings.py文件中.
AUTH_USER_MODEL =’index.CustomUser’
在这里索引是我的CustomUser模型创建的应用程序.
希望这可以帮助.