簡體   English   中英

Python / Django:在發生異常時自動記錄,包括請求信息

[英]Python/Django: automatically log when exceptions occur, including request info

我創建了一個函數log_error(request,traceback),我在異常中調用它。 這會將錯誤信息寫入數據庫。 現在,在我打開每個視圖並將其添加到異常處理程序之前,有沒有辦法自動將所有異常引發到函數,然后調用它?

我已經看到了這個Python錯誤日志記錄 ,它說要編寫自己的sys.excepthook版本。 出現異常時會自動調用此函數。 我嘗試了這個,但是即使我將解決方案復制粘貼到views.py並引發錯誤,也沒有調用my_excepthook。 但是,我並沒有太努力,因為它無法獲得我需要的所有信息。 我還需要請求,以便我可以記錄用戶,網址等信息。

也許那要求太多了?

(我正在使用Django,但這似乎不是Django特有的東西)編輯:是的,確實如此。

JF Sebastian的建議奏效了。 這是一個Django解決方案。

在settings.py MIDDLEWARE_CLASSES中:

(我把它添加為最后一個,不確定這是否正確或將導致錯誤。現在可以工作。)

'myapp.middleware.ExceptionMiddleware',

在myapp.middleware.py中:

import traceback
class ExceptionMiddleware(object):
    def process_exception(self, request, exception):
        log_error(traceback, request)

而已。 log_error是我的函數並寫入數據庫。 從文檔https://docs.djangoproject.com/en/dev/howto/error-reporting/中還可以看出,我可以獲取局部變量以及請求屬性。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM