最近,斗哥在刷CTF题目。突然刷到了内存取证类,了解到了一款牛逼的工具——Volatility,在kali linux也默认安装好了这个工具,正好可以好好学习一波。
Volatility 简介:
Volatility是一款开源的,基于Python开发的内存取证工具集,可以分析内存中的各种数据。Volatility支持对32位或64位Wnidows、Linux、Mac、Android操作系统的RAM数据进行提取与分析。
data:image/s3,"s3://crabby-images/5fc28/5fc286d06584b3690c05152b54e72a638ba6d379" alt=""
题目来源:
还记得取证那题吗?既然有了取证神器,这里有一个可疑文件以及存储该文件电脑的一个内存快照,那么接下来我们实战一下吧。
由于文件比较大,请大家至百度云盘下载:
链接: http://pan.baidu.com/s/1c2BIGLE
密码: 9v2z
打开是2个文件:
data:image/s3,"s3://crabby-images/97e95/97e95ad0a5bc78114bbeeb996d38d43f267b3eb8" alt=""
volatility 使用:
volatility -f <文件名> --profile=<配置文件> <插件> [插件参数]
获取--profile的参数 。
使用imageinfo插件来猜测dump文件的profile值:WinXPSP2x86
root@kali:~/quzhen# volatility -f mem.vmem imageinfo
data:image/s3,"s3://crabby-images/f223f/f223fda62e7f21e251c12424415b4f1cd56f38a8" alt=""
root@kali:~/quzhen# volatility -f mem.vmem --profile=WinXPSP2x86
data:image/s3,"s3://crabby-images/ea322/ea3225955c82c0dd7988bb5ae59f97b68c707437" alt=""
shell的命令:
dt("内核关键数据结构名称")
如:
dt("_PEB")
data:image/s3,"s3://crabby-images/a5a69/a5a69bc57599c2f38f87ae141cd8b5ded7947097" alt=""
列举进程:
root@kali:~/quzhen# volatility -f mem.vmem --profile=WinXPSP2x86 pslist
data:image/s3,"s3://crabby-images/92c22/92c22b51b8bcad87815c4b6eb1fabd2f5b7a940c" alt=""
列举缓存在内存的注册表 :
olatility -f mem.vmem --profile=WinXPSP2x86 hivelist
data:image/s3,"s3://crabby-images/db9cc/db9cc1c813ee7fb0b0bf94d7c8394a665bd335bd" alt=""
hivedump 打印出注册表中的数据 :
volatility -f mem.vmem --profile=WinXPSP2x86 hivedump -o 注册表的 virtual 地址
data:image/s3,"s3://crabby-images/d0d97/d0d975bc167398c5e3aab090fad7704627b5c8fd" alt=""
获取SAM表中的用户:
volatility -f mem.vmem --profile=WinXPSP2x86 printkey -K "SAM\Domains\Account\Users\Names"
可以看到有4个用户。
data:image/s3,"s3://crabby-images/d01e6/d01e68ab9fbbc387e188b4f8e4718016f20cbd9e" alt=""
获取最后登录系统的账户 :
volatility -f mem.vmem --profile=WinXPSP2x86 printkey -K "SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon"
提取出内存中记录的 当时正在运行的程序有哪些,运行过多少次,最后一次运行的时间等信息 。
volatility -f mem.vmem --profile=WinXPSP2x86 userassist
data:image/s3,"s3://crabby-images/c7102/c71025c5f7599527ff73e80190046dc4cca13c9a" alt=""
将内存中的某个进程数据以 dmp 的格式保存出来 。
volatility -f mem.vmem --profile=WinXPSP2x86 -p [PID] -D [dump 出的文件保存的目录]
data:image/s3,"s3://crabby-images/67f9b/67f9b488224eecc7f4b829e385e891ad15399f25" alt=""
二进制编辑器 hexeditor 将以上保存的 dmp 文件打开,并进行调查取证的工作。
hexeditor 1736.dmp
data:image/s3,"s3://crabby-images/5aa00/5aa00ff22817543cb151f2174364a7359214e203" alt=""
你还可以使用 strings 这个工具将它的字符串打印出来。
例:
strings 1736.dmp > 1736.txt
strings 1608.dmp > 1736.txt | grep shellcode
提取内存中保留的 cmd 命令使用情况
volatility -f mem.vmem --profile=WinXPSP2x86 cmdscan
data:image/s3,"s3://crabby-images/19c9b/19c9ba15944af6105f7af05e2f005670d245d2a5" alt=""
获取到当时的网络连接情况。
volatility -f mem.vmem --profile=WinXPSP2x86 netscan
data:image/s3,"s3://crabby-images/cc6ca/cc6ca7f963711982e6916dddf8d8a1633016ac30" alt=""
获取 IE 浏览器的使用情况 :
volatility -f mem.vmem --profile=WinXPSP2x86 iehistory
获取内存中的系统密码,我们可以使用 hashdump 将它提取出来。
volatility -f mem.vmem --profile=WinXPSP2x86 hashdump -y (注册表 system 的 virtual 地址 )-s (SAM 的 virtual 地址)
data:image/s3,"s3://crabby-images/0c4da/0c4da03ad0eb0f70386106ca21c398ab62c4ecd9" alt=""
volatility -f mem.vmem --profile=WinXPSP2x86 hashdump -y 0xe1035b60 -s 0xe16aab60
最大程度上将内存中的信息提取出来,那么你可以使用 timeliner 这个插件。它会从多个位置来收集系统的活动信息 。
volatility -f mem.vmem --profile=WinXPSP2x86 timeliner
解题步骤:
首先解压获得的两个文件,一个是内存文件,另一个是加密文件。
data:image/s3,"s3://crabby-images/97b3a/97b3aca3dba61d46c0409686a08e1e8f608fbb20" alt=""
打开kali,使用volatility 查看进程,可以发现一个TrueCrypy.exe的进程。
root@kali:~/quzhen# volatility -f mem.vmem --profile=WinXPSP2x86 pslist
data:image/s3,"s3://crabby-images/7b7d2/7b7d22c0ffa2c7f0a5fcb4663d347c40d56057c2" alt=""
TrueCrypy.exe是一款加密程序,而我们可以推出,suspicion为加密的结果。
我们需要从内存dump出key来。
volatility -f mem.vmem --profile=WinXPSP2x86 memdump -p 1464 -D ctf/
data:image/s3,"s3://crabby-images/88859/88859e539931e937d0f77ad662fbb130d6c76203" alt=""
dump出来的文件为1464.dmp
Elcomsoft Forensic Disk Decryptor 的使用
我们需要借助Elcomsoft Forensic Disk Decryptor(Elcomsoft硬盘取证解密器,简称为EFDD)软件来获取key和破解文件 。
data:image/s3,"s3://crabby-images/dcf5b/dcf5baeec54299fc9e546be75766487b9535567d" alt=""
data:image/s3,"s3://crabby-images/3a681/3a681c3919f97940f3d2da70d7fe2c329a53fdd5" alt=""
data:image/s3,"s3://crabby-images/90f18/90f185c31dfb209860a34d8124dcf0349d1e27ff" alt=""
data:image/s3,"s3://crabby-images/0ff4d/0ff4d5821d78921f5bcf52a1d50c96b8d53876fc" alt=""
data:image/s3,"s3://crabby-images/288d2/288d24a8e20f215d07eccd5779ac1c6df4b124c9" alt=""
data:image/s3,"s3://crabby-images/02b06/02b063f1e0c8ee069c691edc5eb8f59dedb39035" alt=""
data:image/s3,"s3://crabby-images/74d8e/74d8e753e7d4b94f83dec1fadd08637ceedc5359" alt=""
data:image/s3,"s3://crabby-images/ab72b/ab72bdf4c24a0d73ce3f564136289182569c7e7e" alt=""
data:image/s3,"s3://crabby-images/70e0e/70e0e6cbaf750589eac5b586487047c36370a674" alt=""
data:image/s3,"s3://crabby-images/0ecf7/0ecf7edc6efa4f05cd00e59f40e4ec51f816eada" alt=""
网友评论