我正在使用 Django 2.2
我通过继承自AbstractUser
. 与此同时,我还创建了一个UserManager
.
# ./settings.py
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'django_extensions',
'rest_framework',
'core.apps.AuthConfig'
]
AUTH_USER_MODEL = 'core.User'
# ./core/models.py
class User(AbstractUser):
email = models.EmailField(_('email address'), unique=True)
REQUIRED_FIELDS = ['first_name', 'last_name']
USERNAME_FIELD = 'email'
objects = UserManager()
# ./core/managers.py
class UserManager(BaseUserManager):
def create_user(self, email, password=None, **kwargs):
if not email:
raise ValueError('Email field is required')
email = self.normalize_email(email)
user = self.model(email=email, **kwargs)
user.set_password(password)
user.save()
return user
def create_superuser(self, email, password, **extra_fields):
extra_fields.setdefault('is_staff', True)
extra_fields.setdefault('is_superuser', True)
extra_fields.setdefault('is_active', True)
return self.create_user(email, password, **extra_fields)
当我运行时:
./manage.py makemigrations
./manage.py migrate
我在我的数据库相关组和权限中创建了额外的表。
这样做的目的是什么?难道我做错了什么?
我尝试在 Django admin 中创建一个组并为其分配一些权限。仅使用auth_group
和auth_group_permissions
表。
这些模型来自PermissionsMixin 中定义的 ManyToMany 字段,该字段由AbstractUser继承,后者由您的自定义User模型继承。
groups = models.ManyToManyField(
Group,
verbose_name=_('groups'),
blank=True,
help_text=_(
'The groups this user belongs to. A user will get all permissions '
'granted to each of their groups.'
),
related_name="user_set",
related_query_name="user",
)
user_permissions = models.ManyToManyField(
Permission,
verbose_name=_('user permissions'),
blank=True,
help_text=_('Specific permissions for this user.'),
related_name="user_set",
related_query_name="user",
)
从这里可以看出,组保持用户和组之间的关系,而user_permissions保持用户的特定权限,与用户直接相关(而不是通过组)。
如果您不想要这些,您可以基于AbstractBaseUser类定义您的用户模型。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句