django admin - 你没有权限编辑任何东西

时间:2015-11-05 23:06:41

标签: django django-admin

我跟随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)

我在这里做错了什么?请帮我解决这个问题。谢谢。

3 个答案:

答案 0 :(得分:9)

在这里回答我的问题。所以问题是,PermissionsMixin。我认为PermissionsMixin将处理所有与permssion相关的事情。但即使我将PermissionsMixin添加到新用户模型中,我也必须通过添加is_superuserhas_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