Django Admin自定义用户密码未被哈希+;腌制
我已经创建了一个自定义用户来使用电子邮件而不是用户名。这就是有效的代码 models.pyDjango 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
# 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")