我使用BaseUserManager和AbstractBaseUser创建了用户模型。管理员可以被创建并成功登录。但是,当我添加非管理员用户时,我无法使用它登录我的网站。 因此,超级用户可以登录。其他人创建成功,但无法登录。我不知道问题出在哪里。那是代码(models.py):
from django.contrib.auth.base_user import BaseUserManager, AbstractBaseUser
from django.db import models
class MyUserManager(BaseUserManager):
def create_user(self, email, name = "anynomous", password=None ):
if not email:
raise ValueError('enter your email')
user = self.model(
email=MyUserManager.normalize_email(email),
name = name,
)
user = self.create_user(email,
password=password,
name= name,
)
user.set_password(password)
user.is_superuser = False
user.is_admin = False
user.save(using=self._db)
return user
def create_superuser(self, email, password):
user = self.create_user(email,
password=password,
)
user.is_admin = True
user.is_superuser = True
user.save(using=self._db)
return user
class MyUser(AbstractBaseUser):
email = models.EmailField(max_length=254, unique=True, db_index=True , null=False , blank=False)
name = models.CharField(max_length=50 , null=True, blank=True)
is_active = models.BooleanField(default=True)
is_admin = models.BooleanField(default=False)
objects = MyUserManager()
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = []
def create_user(self, email, name = "anynomous", password=None ):
if not email:
raise ValueError('enter your email')
user = self.model(
email=MyUserManager.normalize_email(email),
name = name,
)
user.set_password(password)
user.is_superuser = False
user.save(using=self._db)
return user
def get_full_name(self):
return self.name
def __unicode__(self):
return self.email
def has_perm(self, perm, obj=None):
return True
def has_module_perms(self, app_label):
return True
@property
def is_staff(self):
return self.is_admin
答案 0 :(得分:0)
您需要在项目的settings.py中添加AUTHENTICATION_BACKENDS
AUTHENTICATION_BACKENDS = [
'django.contrib.auth.backends.ModelBackend'
]
并且已经覆盖了Django的用户模型,因此您需要在settings.py
中提及用户模型的位置。AUTH_USER_MODEL = 'YOUR_User_MODEL_LOCATION'