Django記錄操作日志與LogEntry的使用詳解
前言
LogEntry是在后臺開發(fā)中經(jīng)常用到的模塊,它在admin是默認(rèn)開啟的。
可以使用LogEntry模塊記錄所有用戶的操作記錄。一方面可以用來監(jiān)督,另一方面可以用來做回滾。
1. 使用LogEntry
ModelAdmin本身就有日志記錄功能。當(dāng)新建一個實(shí)體(Post、Category、Tag)時,ModelAdmin會創(chuàng)建一條變更日志記錄。當(dāng)修改一條內(nèi)容時,ModelAdmin又會調(diào)用LogEntry來創(chuàng)建一條日志,記錄這個變更。
ModelAdmin內(nèi)部提供了兩個方法,分別是log_addition和log_change。
log_addition記錄新增日志。
log_change記錄變更日志。
我們可以看它們的定義來學(xué)習(xí)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,
)從以上代碼可以看出:這兩個方法都調(diào)用了LogEntry.objects.log_action方法,只是參數(shù)略有不同,可以看到,如果需要自定義變更記錄的話,只需要傳遞對應(yīng)的參數(shù)即可。以下簡要介紹一下這些參數(shù)。
user_ id
當(dāng)前用戶id。
content_type_id
要保存內(nèi)容的類型,上面的代碼中使用的是get_.content_type_for_model方法拿到對應(yīng)Model的類型id。這可以簡單理解為ContentType為每個Model定義了一個類型id。
object_id
記錄變更實(shí)例的id,比如PostAdmin中它就是post. id。
object_repr
實(shí)例的展示名稱,可以簡單理解為我們定義的__str__所返回的內(nèi)容。
action flag
操作標(biāo)記。admin的Model里面定義了幾種基礎(chǔ)的標(biāo)記: ADDITION、CHANGE和DELETION。它用來標(biāo)記當(dāng)前參數(shù)是數(shù)據(jù)變更、新增,還是刪除。
change_ message
這是記錄的消息,可以自行定義。我們可以把新添加的內(nèi)容放進(jìn)去(必要時可以通過這里來恢復(fù)),也可以把新舊內(nèi)容的區(qū)別放進(jìn)去。
理解了這幾個參數(shù),如果遇到類似的需求,就能直接使用Django現(xiàn)成的工具來完成了。
2. 查詢某個對象的變更
上面我們知道如何記錄某個對象的變更日志了,那么問題來了,如何在詢已經(jīng)記錄的變更呢?
其實(shí)這是簡單的Model查詢問題。假設(shè)我們記錄的對象是Post的操作,現(xiàn)在來獲取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進(jìn)行配置:
#最上面增加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']這樣就可以看到所有的變更記錄了。如下圖所示:

總結(jié)
到此這篇關(guān)于Django記錄操作日志與LogEntry使用的文章就介紹到這了,更多相關(guān)Django記錄操作日志內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
用Python實(shí)現(xiàn)一個簡單的用戶系統(tǒng)
大家好,本篇文章主要講的是用Python實(shí)現(xiàn)一個簡單的用戶系統(tǒng),感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下2022-01-01
詳解python 3.6 安裝json 模塊(simplejson)
這篇文章主要介紹了python 3.6 安裝json 模塊(simplejson),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
Pandas數(shù)據(jù)分組統(tǒng)計(jì)的實(shí)現(xiàn)示例
對數(shù)據(jù)進(jìn)行分組統(tǒng)計(jì),主要適用DataFrame對象的groupby()函數(shù),本文就來詳細(xì)的介紹下Pandas數(shù)據(jù)分組統(tǒng)計(jì)的實(shí)現(xiàn),具有一定的參考價值,感興趣的可以了解下2023-11-11
使用python代碼進(jìn)行身份證號校驗(yàn)的實(shí)現(xiàn)示例
這篇文章主要介紹了使用python代碼進(jìn)行身份證號校驗(yàn)的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
python3 os進(jìn)行嵌套操作的實(shí)例講解
在本篇文章里小編給大家整理了關(guān)于python3 os進(jìn)行嵌套操作的實(shí)例內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。2020-11-11
python 殺死自身進(jìn)程的實(shí)現(xiàn)方法
今天小編就為大家分享一篇python 殺死自身進(jìn)程的實(shí)現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07
Python中if __name__ == "__main__"詳細(xì)解釋
這篇文章主要介紹了Python中if __name__ == "__main__"詳細(xì)解釋,需要的朋友可以參考下2014-10-10

