在Django的项目开发中,需求是要在后台得列表中非管理员用户只列出自己的相关记录。下面我们记录一下 admin.py
详细的代码并给出详解。
class Sale_Admin(admin.ModelAdmin):
list_display = ('customer','idc', 'line_type', 'charge_type', 'saler', 'graph_id', 'alarm_times')
list_per_page = 20
# list_editable = ['graph_id',]
list_filter = ('customer', 'saler')
search_fields = ['customer__name','idc__name','graph_id']
ordering = ('idc',)
readonly_fields = ('v_max', 'v_nf', 'update_time', 'alarm_times')
def get_queryset(self, request):
qs = super(Sale_Admin,self).get_queryset(request)
# if request.user.is_superuser:
# return qs
return qs.filter(saler=23)
def has_add_permission(self, request):
return False
def has_change_permission(self, request, obj=None):
return False
def has_delete_permission(self, request, obj=None):
return False
def has_view_permission(self, request, obj=None):
return False
get_queryset
可以自定义对象列表,比如非管理员登录,我们只显示saler值为23的记录。
当然还可以控制当前用是否能查看、修改、添加、删除权限。
has_add_permission
has_change_permission
has_delete_permission
has_view_permission
则是判断是否具有对应的权限。
发表回复