python - 省略自定义 Django 用户模型的密码字段

标签 python django

我想拥有自己的自定义 Django 用户模型,只有

email id,first_name, last_name and date_joined

字段。我不想有一个密码列,因为身份验证是通过 Microsoft SAML 进行的,因此我不需要存储任何密码。我的用户模型如下:

from __future__ import unicode_literals
from django.db import models
from django.contrib.auth.models import PermissionsMixin, 
                                       BaseUserManager, AbstractBaseUser
from django.utils.translation import ugettext_lazy as _


class UserManager(BaseUserManager):
    def _create_user(self, email, **extra_fields):
        if not email:
            raise ValueError('The Email must be set')
        email = self.normalize_email(email)
        user = self.model(email=email, extra_fields)
        user.save()

        return user

    def create_superuser(self, email, **extra_fields):
        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(email, **extra_fields)


class User(AbstractBaseUser, PermissionsMixin):
    email = models.EmailField(_('email address'), unique=True)
    first_name = models.CharField(_('first name'), max_length=30, blank=True)
    last_name = models.CharField(_('last name'), max_length=30, blank=True)
    date_joined = models.DateTimeField(_('date joined'), auto_now_add=True)

    objects = UserManager()

    USERNAME_FIELD = 'email'
    REQUIRED_FIELDS = ['first_name', 'last_name']

    class Meta:
        verbose_name = _('user')
        verbose_name_plural = _('users')

    def get_full_name(self):
        full_name = f'{self.first_name} {self.last_name}'
        return full_name.strip()

但是,当我运行迁移时,我也可以在用户表中看到密码字段。我做错了什么?

最佳答案

我不能评论所以回复作为答案,但你可以使用“set_unusable_password”来越过密码字段。

https://docs.djangoproject.com/en/2.0/ref/contrib/auth/#django.contrib.auth.models.User.set_unusable_password

像这样:

class UserManager(BaseUserManager):
    def _create_user(self, email, **extra_fields):
        if not email:
            raise ValueError('The Email must be set')
        email = self.normalize_email(email)
        user = self.model(email=email, extra_fields)
        user.set_unusable_password()
        user.save()

        return user

关于python - 省略自定义 Django 用户模型的密码字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55101750/

相关文章:

python - 添加货币和​​百分号而不转换为字符串

python - SymPy - 将数字视为符号

python - 使用 Python 构建 KML

Django 路径,在 windows 中开发,在 linux 上部署

python - django 中的 Endblock 标记无效

python - 如何在 Tensorflow 中将 2 个图像发送到 1 个网络并计算对比损失?

python - Python 中一个非常大的整数的 math.pow 是错误的

python - 如何组合多个 django 查询集聚合和过滤器

django - 查询所有行并返回每个重复项中的最新行

python - 使用 django-filter,为什么未指定或无效的查找类型会返回所有结果?