1.创建MySQL数据库 moderate 表 和 moderate_log(储存记录) 表
2.Django 映射
(1)inspectdb 创建的表
(2) 复制红色的框框的内容,粘贴到 models.py 文件
可以加下面的代码或者不加也行,加的话要映射一下
verbose_name = "Moderate" # 首页列表的显示名称
verbose_name_plural = verbose_name # 列表页和详情页的显示名称
(3) 映射一下
3.在 admin.py 文件 编写代码(核心代码)
from django.contrib import admin
# from 你自己的项目.models import *
from book_MS.models import *
# 日期 可以选择加或者不加
# from django.utils import timezone
@admin.register(Moderate)
# admin.site.register(要写的表) 与 @admin.register(要写的表) 功能是一样的
class ModerateAdmin(admin.ModelAdmin):
"""
*MySQL数据库moderate表:id, 名字, 内容,是否通过, 是否已审核
'id', 'name', 'incident', 'status', 'check'
"""
# listdisplay设置要显示在列表中的字段(id字段是Django模型的默认主键)
list_display = ('name', 'incident', 'status', )
# list_per_page设置每页显示多少条记录,默认是10条
list_per_page = 10
# list_filter过滤指定的字段
list_filter = ('name', )
# 修改admin页面actions的信息
actions = ['mak_pub', 'mak_pub1']
# 判断通过的
def mak_pub(self, request, queryset):
# 获取当前用户的名字
us = request.user
# 打印通过的数据
for i in queryset.filter():
# print(i.id)
# 创建str,如果要加时间的话,就加上下面的代码
# str = '{} {}更改了Moderate表的id为{}的信息:已通过,审核成功!'.format(timezone.now(), us, i.id)
str = '{}更改了Moderate表的id为{}的信息:已通过,审核成功!'.format(us, i.id)
# 插入数据到Log表中
ModerateLog.objects.create(record=str)
# 更新状态和审核
rows_upb = queryset.update(status="1", check="1")
# 如果获取的数是1,则执行下面代码
if rows_upb == 1:
message_bit = "1个视频"
else:
message_bit = "%s 个视频" % rows_upb
# 通过多少的数据,显示到admin页面上
self.message_user(request, "%s 已经通过." % message_bit)
# 更改Action的内容为通过
mak_pub.short_description = "通过"
# 判断未通过的
def mak_pub1(self, request, queryset):
# 获取当前的用户
us = request.user
# 打印未通过的数据
for i in queryset.filter():
print(i)
# 创建str
str = '{}更改了Moderate表的id为{}的信息:未通过,审核成功!'.format(us, i.id)
# 插入数据到Log表中
ModerateLog.objects.create(record=str)
# 更新状态和审核
rows_upb = queryset.update(status="0", check="1")
# 如果获取的数是1,则执行下面代码
if rows_upb == 1:
message_bit = "1个视频"
else:
message_bit = "%s 个视频" % rows_upb
# 通过多少的数据,显示到admin页面上
self.message_user(request, "%s 拒绝通过." % message_bit)
# 更改Action的内容为通过
mak_pub1.short_description = "未通过"
# 重写已经审核过的数据,超级管理员不会通过
def get_queryset(self, request):
# 获取当前表所有的数据
qs = super().get_queryset(request)
# 判断是否未超级管理员,如果是就显示所有(已审核和未审核)的信息,不是就显示未审核的信息
if request.user.is_superuser:
return qs
return qs.filter(check=0)
4.登入 admin 后台管理
(1)先登入超级管理员,创建管理员,然后给管理员的查看和修改 moderate 表 和 moderate_log(储存记录) 表的权限
(2) 记得勾上职员状态,否则无法登陆
5.登入刚刚创建的管理员
6.添加数据测试一下,到MySQL数据库手动输入几条数据
7.效果
(1)点击通过或者未通过,执行后会隐藏,只有超级管理员才能看见,并且会记录到 moderate_log(储存记录)表中