【问题标题】:Custom User Model creates additional groups and permissions table自定义用户模型创建额外的组和权限表
【发布时间】:2019-04-12 22:15:07
【问题描述】:

我正在使用 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_groupauth_group_permissions 表。

【问题讨论】:

    标签: python django


    【解决方案1】:

    这些模型来自 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",
    )
    

    从这里可以看出,groups保持用户和组之间的关系,user_permissions保持用户的特定权限,与用户直接相关(不是通过组)。

    如果您不想要这些,您可以根据 AbstractBaseUser 类定义您的用户模型。

    【讨论】:

      猜你喜欢
      • 2016-07-31
      • 1970-01-01
      • 2013-07-23
      • 2017-05-27
      • 2019-09-17
      • 2019-01-24
      • 2021-06-24
      • 2020-11-02
      • 1970-01-01
      相关资源
      最近更新 更多