我跟随django doc创建自定义用户模型,同时使用我自己的字段扩展模型本身。所以它变成了这样:
class MyUser(AbstractBaseUser, PermissionsMixin):
email = models.EmailField(max_length=255, unique=True)
first_name = models.CharField(max_length=35)
last_name = models.CharField(max_length=35)
username = models.CharField(max_length=70, unique=True)
date_of_birth = models.DateField()
is_active = models.BooleanField(default=True)
is_admin = models.BooleanField(default=False)
@property
def is_staff(self):
return self.is_admin
def get_full_name(self):
return ('%s %s') % (self.first_name, self.last_name)
def get_short_name(self):
return self.username
objects = MyUserManager()
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = ['first_name', 'last_name', 'username', 'date_of_birth']
它的经理是:
class MyUserManager(BaseUserManager):
def create_user(self, email, first_name, last_name, username, date_of_birth, password=None):
if not email:
raise ValueError('User must have an email address')
user = self.model(
email=self.normalize_email(email),
first_name=first_name,
last_name=last_name,
username=username,
date_of_birth=date_of_birth,
)
user.set_password(password)
user.save(using=self._db)
return user
def create_superuser(self, email, first_name, last_name, username, date_of_birth, password):
user = self.create_user(
email,
first_name=first_name,
last_name=last_name,
username=username,
date_of_birth=date_of_birth,
password=password
)
user.is_admin = True
user.save(using=self._db)
return user
但是,在syncdb创建超级用户后,当我登录管理面板时,无所事事。它显示:
您无权修改任何内容。
我看到其他帖子有同样的问题,其中大部分都建议在urls.py中添加admin.autodiscover()
。但即使这对我没有帮助。
这是admin.py:
class MyUserAdmin(UserAdmin):
form = UserChangeForm
add_form = UserCreationForm
list_display = ('email', 'first_name', 'last_name', 'username', 'date_of_birth', 'is_admin')
list_filter = ('is_admin',)
fieldsets = (
(None, {'fields': ('email', 'password')}),
('Personal info', {'fields': (('first_name', 'last_name'), 'username', 'date_of_birth')}),
('Permissions', {'fields': ('is_admin',)}),
)
add_fieldsets = (
(None, {
'classes': ('Wide',),
'fields': ('email', 'first_name', 'last_name', 'username', 'date_of_birth')
}),
)
search_fields = ('email',)
ordering = ('email',)
filter_horizontal = ()
admin.site.register(MyUser, MyUserAdmin)
我在这里做错了什么?请帮我解决这个问题。谢谢。
答案 0 :(得分:9)
在这里回答我的问题。所以问题是,PermissionsMixin。我认为PermissionsMixin将处理所有与permssion相关的事情。但即使我将PermissionsMixin添加到新用户模型中,我也必须通过添加is_superuser
或has_perm
来明确地告诉django超级用户确实是超级用户。
所以我将用户管理器中的功能更改为
def create_superuser(self, email, first_name, last_name, username, date_of_birth, password, **kwargs):
user = self.create_user(
email,
first_name=first_name,
last_name=last_name,
username=username,
date_of_birth=date_of_birth,
password=password,
is_superuser=True,
**kwargs
)
希望这能帮助像我这样的人!
答案 1 :(得分:1)
就我而言,问题出在 venv 中。尝试重新创建它
答案 2 :(得分:0)
在2020年,您需要定义两种方法
spa.UseProxyToSpaDevelopmentServer
模型字段is_superuser ...您可以将is_superuser字段重命名为is_admin或其他任何内容...在这种情况下,您还需要在函数中将is_superuser更改为is_admin