首页 > 作文

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

更新时间:2023-04-04 10:57:12 阅读: 评论:0

前言

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

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

1. 使用logentry

modeladmin本身就有日志记录功能。当新建一个实体(post、category、tag)时,modeladmin会创建一条变更日志记录。当修改一条内容时,modeladmin又会调用logentry来创建一条日志,记录这个变更。

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

log_addition记录新增日志。

log_change记录变更日志。

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

代码位置:django/adm高中物理辅导课程in/contrib/options.py

def log_addition(lf, 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(            ur_id=request.ur.pk,            conten粉色信笺t_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(lf, request, object, message):        """        log that an object has been successfully changed.        the default implementation creates a船海工程n admin logentry object.        """        from django.contrib.admin.models import logentry, change        return logentry.objects.log_action(            ur_id=request.ur.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方法,只是参数略有不同,可以看到,如果需要自定义变更记录的话,只需要传递对应的参数即可。以下简要介绍一下这些参数。

ur_ 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, changefrom django.contrib.admin.options import get_content_type_for_modelpost = 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后台方便地查看操作日志呢?

新增如下配置:

#最上面增加importfrom waste的用法django.contrib.admin.models import logentry#文件最下方增加@adnin.register(logentry, site=custom_site)class logentryadmin(admin.modeladmin):    list_display = ['object_repr','object_ id','action_flag','ur','change_message']

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

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

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

总结

到此这篇关于django记录操作日志与logentry使用的文章就介绍到这了,更多相关django记录操作日志内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

本文发布于:2023-04-04 10:57:10,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/f11afe9b43f99b58ba030d5d991aef36.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:Django记录操作日志与LogEntry的使用详解.doc

本文 PDF 下载地址:Django记录操作日志与LogEntry的使用详解.pdf

标签:日志   操作   内容   定义
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图