Django记录操作日志与LogEntry的使用详解

作者:Edison、23 时间:2022-03-15 11:21:46 

前言

LogEntry是在后台开发中经常用到的模块,它在admin是默认开启的。

可以使用LogEntry模块记录所有用户的操作记录。一方面可以用来监督,另一方面可以用来做回滚。

1. 使用LogEntry

ModelAdmin本身就有日志记录功能。当新建一个实体(Post、Category、Tag)时,ModelAdmin会创建一条变更日志记录。当修改一条内容时,ModelAdmin又会调用LogEntry来创建一条日志,记录这个变更。

ModelAdmin内部提供了两个方法,分别是log_addition和log_change。

log_addition记录新增日志。

log_change记录变更日志。

我们可以看它们的定义来学习LogEntry模块

代码位置:django/admin/contrib/options.py

def log_addition(self, request, object, message):
       """
       Log that an object has been successfully added.

The default implementation creates an admin LogEntry object.
       """
       from django.contrib.admin.models import LogEntry, ADDITION
       return LogEntry.objects.log_action(
           user_id=request.user.pk,
           content_type_id=get_content_type_for_model(object).pk,
           object_id=object.pk,
           object_repr=str(object),
           action_flag=ADDITION,
           change_message=message,
       )

def log_change(self, request, object, message):
       """
       Log that an object has been successfully changed.

The default implementation creates an admin LogEntry object.
       """
       from django.contrib.admin.models import LogEntry, CHANGE
       return LogEntry.objects.log_action(
           user_id=request.user.pk,
           content_type_id=get_content_type_for_model(object).pk,
           object_id=object.pk,
           object_repr=str(object),
           action_flag=CHANGE,
           change_message=message,
       )

从以上代码可以看出:这两个方法都调用了LogEntry.objects.log_action方法,只是参数略有不同,可以看到,如果需要自定义变更记录的话,只需要传递对应的参数即可。以下简要介绍一下这些参数。

user_ id

当前用户id。

content_type_id

要保存内容的类型,上面的代码中使用的是get_.content_type_for_model方法拿到对应Model的类型id。这可以简单理解为ContentType为每个Model定义了一个类型id。

object_id

记录变更实例的id,比如PostAdmin中它就是post. id。

object_repr

实例的展示名称,可以简单理解为我们定义的__str__所返回的内容。

action flag

操作标记。admin的Model里面定义了几种基础的标记: ADDITION、CHANGE和DELETION。它用来标记当前参数是数据变更、新增,还是删除。

change_ message

这是记录的消息,可以自行定义。我们可以把新添加的内容放进去(必要时可以通过这里来恢复),也可以把新旧内容的区别放进去。

理解了这几个参数,如果遇到类似的需求,就能直接使用Django现成的工具来完成了。

2. 查询某个对象的变更

上面我们知道如何记录某个对象的变更日志了,那么问题来了,如何在询已经记录的变更呢?

其实这是简单的Model查询问题。假设我们记录的对象是Post的操作,现在来获取Post中id为1的所有变更日志,大概代码如下:

from django.contrib.admin.models import LogEntry, CHANGE
from django.contrib.admin.options import get_content_type_for_model

post = Post.objects.get(id=1)
log_entries = LogEntry.objects.filter(
   content_type_id=get_content_type_for_model(post).pk,
   object_id=post.id,

这样我们就拿到了文章id为1的所有变更记录了。

3. 在admin页面上查看操作日志

我们既知道如何记录变更日志,也知道如何获取变更日志,那么如何才能够在admin后台方便地查看操作日志呢?

新增如下配置:

#最上面增加import
from django.contrib.admin.models import LogEntry
#文件最下方增加
@adnin.register(LogEntry, site=custom_site)
class LogEntryAdmin(admin.ModelAdmin):
   list_display = ['object_repr','object_ id','action_flag','user','change_message']

如果你配置过xadmin,则在adminx.py进行配置:

#最上面增加import
from django.contrib.admin.models import LogEntry
#文件最下方增加
xadmin.site.register(LogEntry,LogEntryAdmin)
class LogEntryAdmin(object):
   list_display = ['object_repr','object_id','action_flag','user','change_message']

这样就可以看到所有的变更记录了。如下图所示:

Django记录操作日志与LogEntry的使用详解

总结 

来源:https://www.cnblogs.com/zihao1037/p/11057341.html

标签:django,日志,logentry
0
投稿

猜你喜欢

  • 如何在scrapy中捕获并处理各种异常

    2023-04-10 06:56:23
  • Python的子线程和子进程是如何手动结束的?

    2022-09-08 18:54:41
  • 解析go语言调用约定多返回值实现原理

    2023-10-08 23:38:06
  • python人物视频背景替换实现虚拟空间穿梭

    2023-06-11 06:58:30
  • python 七种邮件内容发送方法实例

    2022-01-13 21:06:38
  • Python开发之pip安装及使用方法详解

    2022-11-27 06:22:48
  • Python获取android设备cpu和内存占用情况

    2023-02-25 20:46:47
  • CSS中的标点符号用法

    2008-10-03 11:58:00
  • 基于python实现图片转字符画代码实例

    2023-05-17 01:53:37
  • js图片随机显示技巧

    2007-08-19 20:20:00
  • PHP strip_tags() 去字符串中的 HTML、XML 以及 PHP 标签的函数

    2023-06-09 01:05:00
  • 解决Python的str强转int时遇到的问题

    2023-02-28 23:03:02
  • 解读python基于netconf协议获取网元的数据

    2023-06-29 20:26:23
  • Python教程之基本运算符的使用(上)

    2023-12-16 23:11:40
  • 功能强大,代码简单的管理菜单

    2008-07-11 16:52:00
  • 对Python实现简单的API接口实例讲解

    2023-11-20 03:27:04
  • ASP读取Exif信息无组件实现过程

    2009-02-09 12:52:00
  • Oracle存储过程基本语法介绍

    2023-06-27 14:00:26
  • Python中单线程、多线程和多进程的效率对比实验实例

    2022-12-01 09:25:55
  • Python 函数装饰器详解

    2021-11-20 04:34:16
  • asp之家 网络编程 m.aspxhome.com