Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Django Admin自定义用户密码未被哈希+;腌制_Django_Django Admin - Fatal编程技术网

Django Admin自定义用户密码未被哈希+;腌制

Django Admin自定义用户密码未被哈希+;腌制,django,django-admin,Django,Django Admin,我已经创建了一个自定义用户来使用电子邮件而不是用户名。这就是有效的代码 models.py # Overriding the default users model from django.contrib.auth.base_user import BaseUserManager from django.utils.translation import ugettext_lazy as _ from django.db import models from django.contrib.aut

我已经创建了一个自定义用户来使用电子邮件而不是用户名。这就是有效的代码

models.py

 # Overriding the default users model
from django.contrib.auth.base_user import BaseUserManager
from django.utils.translation import ugettext_lazy as _
from django.db import models
from django.contrib.auth.models import AbstractUser


class CustomUserManager(BaseUserManager):
    """
    Custom user model manager where email is the unique identifiers
    for authentication instead of usernames.
    """
    def create_user(self, email, password, **extra_fields):
        """
        Create and save a User with the given email and password.
        """
        if not email:
            raise ValueError(_('The Email must be set'))
        email = self.normalize_email(email)
        user = self.model(email=email, **extra_fields)
        user.set_password(password)
        user.save()
        return user

    def create_superuser(self, email, password, **extra_fields):
        """
        Create and save a SuperUser with the given email and password.
        """
        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, password, **extra_fields)


class CustomUser(AbstractUser):
    username = None
    email = models.EmailField(_('email address'), unique=True)

    USERNAME_FIELD = 'email'
    REQUIRED_FIELDS = []

    objects = CustomUserManager()

    def __str__(self):
        return self.email
并将其注册到管理模式以获得更灵活的列表。(admin.py)

现在的问题是,当我添加一个新用户时,我设置的密码是明文,因此不起作用。它需要散列和腌制,我认为“user.set_password”应该这样做。检查代码,这是用户类的默认函数,应该可以正常工作。但是,我可以在表单上看到明文用户密码,并且无论如何都无法登录(这是正常的,因为登录尝试匹配哈希+盐密码来登录)。考虑到我是django新手,任何好的线索都非常感谢:)

我错过了什么?为什么set_password函数不能正确散列密码?我可以通过控制台看到我创建的用户的salted+hash密码(从pbkdf2_sha256$260000$..开始),它还使用相同的set_password函数,对吗

注意:自定义用户代码不是我自己的,而是来自另一个源代码,但我无法确定是哪个url,因此无法在此处真正共享引用

注2:我相信这个主题的核心与我的主题相同,但我未能通过其中的答案找到线索

注3:这非常相似,但因为我已经覆盖了模式,所以我不能使用UserAdmin(错误为“ordering[0]”的值指的是“username”,它不是“users.CustomUser”的属性)

from django.contrib import admin
from .models import CustomUser


@admin.register(CustomUser)
class CustomUserADM(admin.ModelAdmin):
    list_display = ("email", "is_staff", "is_active")