实战揭秘Windows可执行文件运行痕迹
时间:2025-05-27 12:03:27 282浏览 收藏
在Windows系统上,通过分析可执行文件运行痕迹,可以重建用户活动时间线,揭示谁在何时何地运行了哪些应用程序。本文详细介绍了三种主要的证据来源:链接文件(LNK文件)、跳转列表(Jump Lists)和系统资源监视器(SRUM)。链接文件存储在用户的Recent文件夹中,记录了最近访问的文件信息,即使原文件被删除,LNK文件仍会保留。跳转列表分为AutomaticDestinations和CustomDestinations,分别用于自动生成和用户固定文件,帮助快速访问最近打开的文件或文件夹。系统资源监视器则通过SRUM数据库跟踪资源使用情况,提供了过去30天的应用程序数据,包括可执行文件路径和CPU使用时间等信息。通过这些证据,可以有效提取和分析用户在Windows系统上的操作痕迹。
文章来源|MS08067蓝队手册
前言
在Windows系统上可以找到的许多证据,可以重建时间线,展示谁在何时何地运行了哪些应用程序以及如何从中提取有意义的数据。内存取证不在这里的讨论范围,我们主要关注可执行文件运行的的证据
链接文件
链接文件是Windows操作系统中的一种快捷方式文件,用于快速访问指向的文件。它们存储了有关目标文件或文件夹的元数据信息【以及其要执行的操作。考虑是否去掉]。
Windows使用文件夹(C:\U\%USERNAME%\AppData\Roaming\Microsoft\Windows\Recent)来存储用户最近访问的文件关联的LNK 文件。对于特定文件名,仅记录最新的打开操作,链接文件都会被最新一次的文件访问记录覆盖。而如果文件本身已被删除,LNK 文件仍然保留在 Recent 目录中。
在Windows资源管理器中查看该目录时,即使在文件夹选项中选择了“显示文件扩展名”,Ink扩展名也不会显示。
然而这些文件完整名称可以通过命令行查看

使这样能看到扩展名,并不能说明这些文件或者文件夹实际存储在磁盘上。所以,需要借助例如:
LECmd这样的工具(https://ericzimmerman.github.)io/这里以afxres.h.lnk文件演示。


在这里我们可以看到文件的绝对路径是C:\temp\users.txt
跳转列表
跳转列表(Jump Lists)由应用软件或者系统创建,作用是方便用户可以直接跳转到最近打开的文件或文件夹,其具有两种类型,AutomaticDestinations和CustomDestinations。
其中AutomaticDestinations是在运行与文件关联的应用程序时自动生成(C:\Users\%USERNAME%\AppData\Roaming\Microsoft\Windows\RecentVAutomaticDestinatio ns,)位置,并以CDF 格式存储;
而CustomDestinations 文件夹同样存储在 Recent 文件夹中,但它们是在用户将文件“固定”到开始菜单或任务栏时创建的。
这两种类型的文件夹都可以显示用户对特定文件或应用程序的交互情况。查看这两个文件夹时,每个应用程序关联的文件都会带有后缀“-ms”和一个AppID。


关于AppID的具体含义这里不详细描述,可自行寻找资料了解。另外已有很多网站整理了大量的 AppID列表。
https://gist.github.com/atilaromero/2146441
https://community.malforensics.com/t/list-of-jump-list-ids/158/1
Jump Lists文件包含有价值的信息,有助于查看特定应用程序曾经交互过的文件及其他相关信息,包括应用程序上次运行的时间以及打开的文件或快捷方式(LNK)。要解析这些信息,可以借助Eric Zimmerman的JLECmd 这样的工具。(https://ericzimmerman.github.io/)。

系统资源监视器
平常我们经常使用任务管理器查看正在运行的应用程序,而任务管理器只显示了系统资源监视器(SRUM)数据库存储数据中的一小部分,该数据库在Windows8中引入,用于跟踪资源使用情况。
该数据库位于C:\Windows\system32\sru\SRUDB.dat
SRUDB.dat是一个可扩展存储引擎(ESE)数据库。在运行过程中,Windows会暂时将这些数据存储在HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\SRUM\Extensions中,并在关机时写入SRUDB.dat。SRUM包含大量关于用户活动的信息,包括可执行文件的完整路径、前台和后台的CPU时间,以及负责执行的SID。在SRUM中,你可以找到过去30天的应用程序数据。在取证过程中有三个需要重点关注的表:
{973F5D5C-1D90-4944-BE8E-24B94231A174}=网络数据使用情况{d10ca2fe-6fcf-4f6d-848e-b2e99266fa89}=应用程序资源使用情况{DD6636C4-8929-4683-974E-22C046A43763}=网络连接使用情况我们可以借助工具SRUM Dump 2(https://github.com/MarkBaggett/srum-dump)去尝试获取实时的SRUDB.dat或SOFTWARE注册表配置单元。

SRUM Dump 2会提示下载fget工具以生成SRUDB.dat或SOFTWRE注册表配置单元两个文件的副本。只需要按照提示进行操作即可。

最后会生成一个名为SRUM_DUMP_OUTPUT.xlsx的输出文件,该文件包含可执行文件、运行该可执行文件的SID、日期时间、网络使用情况以及大量其他与资源相关的信息。

参考
https://inria.hal.science/hal- 88839/document
https://blog.csdn.net/qq_38154820/article/details/118384316
https://gist.github.com/atilaromero/2146441
https://ericzimmerman.github.io
https://github.com/MarkBaggett/srum-dump
今天关于《实战揭秘Windows可执行文件运行痕迹》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于LNK文件,跳转列表,系统资源监视器,SRUM,用户活动时间线的内容请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
162 收藏
-
384 收藏
-
319 收藏
-
126 收藏
-
155 收藏
-
348 收藏
-
204 收藏
-
275 收藏
-
436 收藏
-
150 收藏
-
158 收藏
-
459 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习