我创建了脚本rekall_offset_finder.py,该脚本正在导入rekall内存取证框架,以从内存转储中提取各种内核偏移。
我遇到了一个日志输出的问题,我觉得我不能完全控制它。
首先,在导入库时,我不得不使用一个小黑客来删除Rekall的logging.basicConfig()
,这样我就可以配置自己的日志级别:
# remove Rekall basicConfig()
for handler in logging.root.handlers[:]:
logging.root.removeHandler(handler)
# configure my logging level
logging.basicConfig(level=log_level)
现在,我仍然收到令人讨厌的输出消息:
./rekall_offset_finder.py -u qemu:///session winxp
INFO:root:Dumping winxp physical memory to /tmp/tmpsuam8btj/tmpa30uvrc5
WARNING:root:Unable to determine file size, assuming file is volatile.
INFO:root:Autodetected physical address space Elf64CoreDump
INFO:root:Loaded profile pe from Local Cache - (in 0.0884544849395752 sec)
INFO:root:Loaded profile nt/GUID/7075F995A48A414F8F7BE9A1E0240F821 from Local Cache - (in 0.21683239936828613 sec)
INFO:root:Loaded profile nt/eprocess_index from Local Cache - (in 0.19333624839782715 sec)
INFO:root:Detected ntkrpamp.pdb with GUID 7075F995A48A414F8F7BE9A1E0240F821
INFO:root:Detected kernel base at 0x804D7000
Trying to fetch http://msdl.microsoft.com/download/symbols/ntkrpamp.pdb/7075F995A48A414F8F7BE9A1E0240F821/ntkrpamp.pdb
INFO:root:Loaded profile mspdb from Local Cache - (in 0.08299803733825684 sec)
其中一些信息不是我的。
我知道我可以打电话给logging.getLogger(name).setLevel(logging.WARNING)
让他们安静下来
->如何确定要静音的记录器的名称?
->有没有办法列出所有可用的记录器
谢谢!
解决方案已由@hoefling提供给我。
我把我的根记录器作为Rekall的会话记录器。
通过删除它,Rekall必须创建自己的记录器,并且它有了一个新的名称空间:rekall.1
:
WARNING:rekall.1:Unable to determine file size, assuming file is volatile.
为了让它安静下来,我使用了:
logging.getLogger('rekall.1').setLevel(logging.CRITICAL)
要确定可用的记录器,您可以使用:
logging.Logger.manager.loggerDict.keys()
谢谢!