自定义用户模型无法在django admin上运行

时间:2016-05-28 21:00:22

标签: python django

我创建了一个应用身份验证,代码是模型,

from django.contrib.auth.models import AbstractBaseUser
from django.contrib.auth.models import BaseUserManager
from django.db import models

class AccountManager(BaseUserManager):
    def create_user(self, email, password=None, **kwargs):
        if not email:
            raise ValueError('Users must have a valid email address.')

        account = self.model(email=self.normalize_email(email))

        account.set_password(password)
        account.save()

        return account

    def create_superuser(self, email, password, **kwargs):
        account = self.create_user(email, password, **kwargs)

        account.is_admin = True
        account.save()
        return account


class Account(AbstractBaseUser):
    email = models.EmailField(unique=True)
    # username = models.CharField(max_length=40, unique=True)

    first_name = models.CharField(max_length=40, blank=True)
    last_name = models.CharField(max_length=40, blank=True)

    is_admin = models.BooleanField(default=False)
    is_staff = models.BooleanField(default=False)

    created_at = models.DateTimeField(auto_now_add=True)
    updated_at = models.DateTimeField(auto_now=True)

    objects = AccountManager()

    USERNAME_FIELD = 'email'
    REQUIRED_FIELDS = []

    def __unicode__(self):
        return self.email

    def get_full_name(self):
        return ' '.join([self.first_name, self.last_name])

    def get_short_name(self):
        return self.first_name

除此之外,我所做的更改是在INSTALLED_APPS和添加AUTH_USER_MODEL = 'authentication.Account'的设置中添加了身份验证

当我从shell创建超级用户时,它在db中工作和插入,但是当我尝试登录django管理控制台时, 最初错误是is_staff未找到,我补充说。现在它显示所有人的用户名和密码无效。我尝试了几次每次生成一个新的。我做错了什么?

修改

我正在添加用于验证用户是否已创建的dbs转储

sqlite> select * from authentication_account;
1|pbkdf2_sha256$24000$ZRHCXpUI3w0G$fh4z9y5vmYAZ0FEiDr908dJD3ezw62nm3lpkZxUi/Es=||me@rahulbhola.in|||1|0|2016-05-28 21:15:59.292988|2016-05-28 21:15:59.415382

仍然登录django defaut admin无法正常工作

1 个答案:

答案 0 :(得分:1)

您稍后添加了 is_staff ,默认情况下似乎为false,因此迁移时,该字段是在is_staff字段中的值为false的数据库中创建的。

请进行如下更改并尝试

class AccountManager(BaseUserManager):
    def create_user(self, email, password=None, **kwargs):
        if not email:
            raise ValueError('Users must have a valid email address.')

        account = self.model(email=self.normalize_email(email))

        account.set_password(password)
        account.save(using=self.db)

        return account

    def create_superuser(self, email, password, **kwargs):
        account = self.create_user(email, password, **kwargs)
        account.is_staff = True
        account.is_admin = True
        account.save(using=self.db)

        return account

请不要在上面的代码中使用account.save(using = self.db),并在create admin方法中使用account.is_staff = True。 请尝试再次创建新用户我更喜欢使用shell(python manage.py shell)

  

来自authentication.models导入帐户

     

user = Account()

     

user.create_superuser(username ='some_username',password ='some_password')

     

user.save()

现在用户已创建,请尝试使用django admin登录。 这应该工作。我有类似的问题已修复,我可以从django admin创建用户和登录。

我假设您已经创建了自定义身份验证后端,如果没有请创建

希望这会对你有所帮助。