在Django admin中,我有4个用户和一个超级用户。我有一些带有员工状态的用户,他们具有有限的访问权限,无法删除/查看/编辑其他用户,但管理员对其他所有用户和模型都具有授权。我希望超级用户能够访问用户数据并编辑/修改/删除它们,但我不希望超级用户能够删除自己。目前,超级用户可以删除自己。在Django中是否有一种禁用超级用户删除自己的方法?谢谢。
不要使用has_delete_permission()覆盖,因为在从更改列表执行删除操作时,它不会在每个对象上被调用。
使用信号来完成。将此添加到任何models.py中。
from django.db.models.signals import pre_delete
from django.dispatch.dispatcher import receiver
from django.contrib.auth.models import User
from django.core.exceptions import PermissionDenied
@receiver(pre_delete, sender=User)
def delete_user(sender, instance, **kwargs):
if instance.is_superuser:
raise PermissionDenied
这种方法唯一的缺点是没有人能够删除任何超级用户。在删除之前,您必须将用户属性“is_superuser”设置为False。
UserAdmin
,以使其不允许删除,具体文档请参见这里。from django.contrib import admin
from django.contrib.auth.admin import UserAdmin
from django.contrib.auth.models import User
class MyUserAdmin(UserAdmin):
def has_delete_permission(self, request, obj=None):
if obj is None:
return True
else:
return not obj.is_superuser
admin.site.unregister(User)
admin.site.register(User, MyUserAdmin)
obj=None
调用该函数。您可以通过在obj=None
时返回False
来抑制从列表中删除,或者通过覆盖queryset
函数(在Django 1.6中为get_queryset
)来隐藏超级用户。 - augustomen