91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django記錄操作日志與LogEntry的使用方法是什么

發布時間:2022-01-07 17:47:54 來源:億速云 閱讀:184 作者:iii 欄目:開發技術

這篇文章主要介紹“Django記錄操作日志與LogEntry的使用方法是什么”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Django記錄操作日志與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的使用方法是什么

關于“Django記錄操作日志與LogEntry的使用方法是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

象州县| 苏尼特右旗| 元谋县| 芦溪县| 乌审旗| 台安县| 施秉县| 泗阳县| 禹城市| 马山县| 湘西| 嘉善县| 邓州市| 金平| 辽阳市| 辽宁省| 桦甸市| 中牟县| 临沂市| 濉溪县| 万荣县| 英山县| 深圳市| 本溪市| 鄯善县| 原平市| 宁强县| 宾阳县| 观塘区| 雅江县| 明水县| 壤塘县| 黔东| 保康县| 朝阳区| 瑞丽市| 安福县| 普洱| 托克逊县| 全椒县| 武城县|