Volatility - CheatSheet
Reading time: 20 minutes
tip
AWS 해킹 배우기 및 연습하기:HackTricks Training AWS Red Team Expert (ARTE)
GCP 해킹 배우기 및 연습하기: HackTricks Training GCP Red Team Expert (GRTE)
HackTricks 지원하기
- 구독 계획 확인하기!
- **💬 디스코드 그룹 또는 텔레그램 그룹에 참여하거나 트위터 🐦 @hacktricks_live를 팔로우하세요.
- HackTricks 및 HackTricks Cloud 깃허브 리포지토리에 PR을 제출하여 해킹 트릭을 공유하세요.
메모리 분석을 자동화하고 다양한 스캔 레벨로 여러 Volatility3 플러그인을 병렬로 실행하는 도구가 필요하다면, autoVolatility3를 사용할 수 있습니다: https://github.com/H3xKatana/autoVolatility3/
# Full scan (runs all plugins)
python3 autovol3.py -f MEMFILE -o OUT_DIR -s full
# Minimal scan (runs a limited set of plugins)
python3 autovol3.py -f MEMFILE -o OUT_DIR -s minimal
# Normal scan (runs a balanced set of plugins)
python3 autovol3.py -f MEMFILE -o OUT_DIR -s normal
빠르고 미친 듯한 것을 원한다면 여러 Volatility 플러그인을 병렬로 실행할 수 있는 다음을 사용할 수 있습니다: https://github.com/carlospolop/autoVolatility
python autoVolatility.py -f MEMFILE -d OUT_DIRECTORY -e /home/user/tools/volatility/vol.py # It will use the most important plugins (could use a lot of space depending on the size of the memory)
설치
volatility3
git clone https://github.com/volatilityfoundation/volatility3.git
cd volatility3
python3 setup.py install
python3 vol.py —h
volatility2
Download the executable from https://www.volatilityfoundation.org/26
Volatility 명령어
공식 문서는 Volatility 명령어 참조에서 확인할 수 있습니다.
“list”와 “scan” 플러그인에 대한 주의사항
Volatility는 플러그인에 대해 두 가지 주요 접근 방식을 가지고 있으며, 이는 때때로 이름에 반영됩니다. “list” 플러그인은 Windows 커널 구조를 탐색하여 프로세스(메모리에서 _EPROCESS
구조의 연결 리스트를 찾고 탐색)와 OS 핸들(핸들 테이블을 찾고 나열하며, 발견된 포인터를 역참조 등)과 같은 정보를 검색하려고 합니다. 이들은 요청 시 Windows API처럼 동작합니다. 예를 들어, 프로세스를 나열하는 경우입니다.
이로 인해 “list” 플러그인은 꽤 빠르지만, 악성 소프트웨어에 의해 조작될 수 있는 Windows API와 마찬가지로 취약합니다. 예를 들어, 악성 소프트웨어가 DKOM을 사용하여 프로세스를 _EPROCESS
연결 리스트에서 분리하면, 작업 관리자에 나타나지 않으며 pslist에서도 나타나지 않습니다.
반면 “scan” 플러그인은 특정 구조로 역참조될 때 의미가 있을 수 있는 것들을 메모리에서 조각내는 접근 방식을 취합니다. 예를 들어, psscan
은 메모리를 읽고 _EPROCESS
객체를 만들려고 시도합니다(구조의 존재를 나타내는 4바이트 문자열을 검색하는 풀 태그 스캐닝을 사용합니다). 장점은 종료된 프로세스를 찾아낼 수 있으며, 악성 소프트웨어가 _EPROCESS
연결 리스트를 조작하더라도 플러그인은 여전히 메모리에서 구조를 찾아낼 수 있습니다(프로세스가 실행되기 위해서는 여전히 존재해야 하므로). 단점은 “scan” 플러그인이 “list” 플러그인보다 약간 느리며, 때때로 잘못된 긍정 결과를 초래할 수 있습니다(너무 오래 전에 종료된 프로세스와 그 구조의 일부가 다른 작업에 의해 덮어씌워진 경우).
출처: http://tomchop.me/2016/11/21/tutorial-volatility-plugins-malware-analysis/
OS 프로파일
Volatility3
readme에 설명된 바와 같이 지원하려는 OS의 심볼 테이블을 _volatility3/volatility/symbols_에 넣어야 합니다.
다양한 운영 체제에 대한 심볼 테이블 팩은 다운로드할 수 있습니다:
- https://downloads.volatilityfoundation.org/volatility3/symbols/windows.zip
- https://downloads.volatilityfoundation.org/volatility3/symbols/mac.zip
- https://downloads.volatilityfoundation.org/volatility3/symbols/linux.zip
Volatility2
외부 프로파일
지원되는 프로파일 목록을 얻으려면 다음을 수행할 수 있습니다:
./volatility_2.6_lin64_standalone --info | grep "Profile"
새로 다운로드한 프로필을 사용하려면 (예: 리눅스 프로필) 다음 폴더 구조를 생성해야 합니다: plugins/overlays/linux 이 폴더 안에 프로필이 포함된 zip 파일을 넣습니다. 그런 다음, 프로필의 번호를 얻으려면 다음을 사용하세요:
./vol --plugins=/home/kali/Desktop/ctfs/final/plugins --info
Volatility Foundation Volatility Framework 2.6
Profiles
--------
LinuxCentOS7_3_10_0-123_el7_x86_64_profilex64 - A Profile for Linux CentOS7_3.10.0-123.el7.x86_64_profile x64
VistaSP0x64 - A Profile for Windows Vista SP0 x64
VistaSP0x86 - A Profile for Windows Vista SP0 x86
Linux 및 Mac 프로필을 다운로드할 수 있습니다 https://github.com/volatilityfoundation/profiles
이전 부분에서 프로필 이름이 LinuxCentOS7_3_10_0-123_el7_x86_64_profilex64
인 것을 볼 수 있으며, 이를 사용하여 다음과 같은 작업을 실행할 수 있습니다:
./vol -f file.dmp --plugins=. --profile=LinuxCentOS7_3_10_0-123_el7_x86_64_profilex64 linux_netscan
프로필 발견
volatility imageinfo -f file.dmp
volatility kdbgscan -f file.dmp
imageinfo와 kdbgscan의 차이점
여기에서: profile 제안을 단순히 제공하는 imageinfo와 달리, kdbgscan은 올바른 프로필과 올바른 KDBG 주소(여러 개가 있을 경우)를 긍정적으로 식별하도록 설계되었습니다. 이 플러그인은 Volatility 프로필과 연결된 KDBGHeader 서명을 스캔하고 잘못된 긍정 결과를 줄이기 위해 정상성 검사를 적용합니다. 출력의 상세도와 수행할 수 있는 정상성 검사 수는 Volatility가 DTB를 찾을 수 있는지에 따라 달라지므로, 이미 올바른 프로필을 알고 있거나 imageinfo에서 프로필 제안을 받은 경우, 반드시 그것을 사용해야 합니다.
항상 kdbgscan이 찾은 프로세스 수를 확인하세요. 때때로 imageinfo와 kdbgscan은 하나 이상의 적합한 프로필을 찾을 수 있지만, 유효한 프로필만 프로세스와 관련된 정보를 가집니다(이는 프로세스를 추출하기 위해 올바른 KDBG 주소가 필요하기 때문입니다).
# GOOD
PsActiveProcessHead : 0xfffff800011977f0 (37 processes)
PsLoadedModuleList : 0xfffff8000119aae0 (116 modules)
# BAD
PsActiveProcessHead : 0xfffff800011947f0 (0 processes)
PsLoadedModuleList : 0xfffff80001197ac0 (0 modules)
KDBG
커널 디버거 블록은 Volatility에서 KDBG로 언급되며, Volatility와 다양한 디버거가 수행하는 포렌식 작업에 필수적입니다. KdDebuggerDataBlock
으로 식별되며 _KDDEBUGGER_DATA64
유형을 가지며, PsActiveProcessHead
와 같은 필수 참조를 포함합니다. 이 특정 참조는 프로세스 목록의 헤드를 가리키며, 모든 프로세스를 나열할 수 있게 하여 철저한 메모리 분석에 기본적입니다.
OS 정보
#vol3 has a plugin to give OS information (note that imageinfo from vol2 will give you OS info)
./vol.py -f file.dmp windows.info.Info
플러그인 banners.Banners
는 vol3에서 덤프에서 리눅스 배너를 찾기 위해 사용할 수 있습니다.
해시/비밀번호
SAM 해시, 도메인 캐시 자격 증명 및 lsa 비밀을 추출합니다.
./vol.py -f file.dmp windows.hashdump.Hashdump #Grab common windows hashes (SAM+SYSTEM)
./vol.py -f file.dmp windows.cachedump.Cachedump #Grab domain cache hashes inside the registry
./vol.py -f file.dmp windows.lsadump.Lsadump #Grab lsa secrets
메모리 덤프
프로세스의 메모리 덤프는 프로세스의 현재 상태를 모두 추출합니다. procdump 모듈은 코드만 추출합니다.
volatility -f file.dmp --profile=Win7SP1x86 memdump -p 2168 -D conhost/
프로세스
프로세스 목록
의심스러운 프로세스(이름으로) 또는 예상치 못한 자식 프로세스(예: iexplorer.exe의 자식으로 cmd.exe)를 찾으려고 시도하십시오.
pslist의 결과를 psscan의 결과와 비교하여 숨겨진 프로세스를 식별하는 것이 흥미로울 수 있습니다.
python3 vol.py -f file.dmp windows.pstree.PsTree # Get processes tree (not hidden)
python3 vol.py -f file.dmp windows.pslist.PsList # Get process list (EPROCESS)
python3 vol.py -f file.dmp windows.psscan.PsScan # Get hidden process list(malware)
덤프 프로세스
./vol.py -f file.dmp windows.dumpfiles.DumpFiles --pid <pid> #Dump the .exe and dlls of the process in the current directory
명령줄
의심스러운 것이 실행되었나요?
python3 vol.py -f file.dmp windows.cmdline.CmdLine #Display process command-line arguments
cmd.exe
에서 실행된 명령은 conhost.exe
(또는 Windows 7 이전 시스템의 경우 csrss.exe
)에 의해 관리됩니다. 이는 공격자가 메모리 덤프가 얻어지기 전에 **cmd.exe
**를 종료하더라도 **conhost.exe
**의 메모리에서 세션의 명령 기록을 복구할 수 있음을 의미합니다. 이를 위해 콘솔의 모듈 내에서 비정상적인 활동이 감지되면 관련된 conhost.exe
프로세스의 메모리를 덤프해야 합니다. 그런 다음 이 덤프 내에서 strings를 검색하여 세션에서 사용된 명령줄을 추출할 수 있습니다.
환경
각 실행 중인 프로세스의 환경 변수를 가져옵니다. 흥미로운 값이 있을 수 있습니다.
python3 vol.py -f file.dmp windows.envars.Envars [--pid <pid>] #Display process environment variables
토큰 권한
예상치 못한 서비스에서 권한 토큰을 확인하십시오.
특권 토큰을 사용하는 프로세스를 나열하는 것이 흥미로울 수 있습니다.
#Get enabled privileges of some processes
python3 vol.py -f file.dmp windows.privileges.Privs [--pid <pid>]
#Get all processes with interesting privileges
python3 vol.py -f file.dmp windows.privileges.Privs | grep "SeImpersonatePrivilege\|SeAssignPrimaryPrivilege\|SeTcbPrivilege\|SeBackupPrivilege\|SeRestorePrivilege\|SeCreateTokenPrivilege\|SeLoadDriverPrivilege\|SeTakeOwnershipPrivilege\|SeDebugPrivilege"
SIDs
프로세스가 소유한 각 SSID를 확인하십시오.
특권 SID를 사용하는 프로세스(및 일부 서비스 SID를 사용하는 프로세스)를 나열하는 것이 흥미로울 수 있습니다.
./vol.py -f file.dmp windows.getsids.GetSIDs [--pid <pid>] #Get SIDs of processes
./vol.py -f file.dmp windows.getservicesids.GetServiceSIDs #Get the SID of services
핸들
프로세스가 핸들을 가지고 있는 다른 파일, 키, 스레드, 프로세스 등에 대한 정보를 아는 것이 유용합니다.
vol.py -f file.dmp windows.handles.Handles [--pid <pid>]
DLLs
./vol.py -f file.dmp windows.dlllist.DllList [--pid <pid>] #List dlls used by each
./vol.py -f file.dmp windows.dumpfiles.DumpFiles --pid <pid> #Dump the .exe and dlls of the process in the current directory process
프로세스별 문자열
Volatility는 문자열이 어떤 프로세스에 속하는지 확인할 수 있게 해줍니다.
strings file.dmp > /tmp/strings.txt
./vol.py -f /tmp/file.dmp windows.strings.Strings --strings-file /tmp/strings.txt
이것은 또한 yarascan 모듈을 사용하여 프로세스 내에서 문자열을 검색할 수 있게 해줍니다:
./vol.py -f file.dmp windows.vadyarascan.VadYaraScan --yara-rules "https://" --pid 3692 3840 3976 3312 3084 2784
./vol.py -f file.dmp yarascan.YaraScan --yara-rules "https://"
UserAssist
Windows는 UserAssist keys라는 레지스트리 기능을 사용하여 실행한 프로그램을 추적합니다. 이 키는 각 프로그램이 실행된 횟수와 마지막 실행 시간을 기록합니다.
./vol.py -f file.dmp windows.registry.userassist.UserAssist
서비스
./vol.py -f file.dmp windows.svcscan.SvcScan #List services
./vol.py -f file.dmp windows.getservicesids.GetServiceSIDs #Get the SID of services
네트워크
./vol.py -f file.dmp windows.netscan.NetScan
#For network info of linux use volatility2
레지스트리 하이브
사용 가능한 하이브 인쇄
./vol.py -f file.dmp windows.registry.hivelist.HiveList #List roots
./vol.py -f file.dmp windows.registry.printkey.PrintKey #List roots and get initial subkeys
값을 가져오기
./vol.py -f file.dmp windows.registry.printkey.PrintKey --key "Software\Microsoft\Windows NT\CurrentVersion"
덤프
#Dump a hive
volatility --profile=Win7SP1x86_23418 hivedump -o 0x9aad6148 -f file.dmp #Offset extracted by hivelist
#Dump all hives
volatility --profile=Win7SP1x86_23418 hivedump -f file.dmp
파일 시스템
마운트
#See vol2
스캔/덤프
./vol.py -f file.dmp windows.filescan.FileScan #Scan for files inside the dump
./vol.py -f file.dmp windows.dumpfiles.DumpFiles --physaddr <0xAAAAA> #Offset from previous command
마스터 파일 테이블
# I couldn't find any plugin to extract this information in volatility3
NTFS 파일 시스템은 마스터 파일 테이블 (MFT)로 알려진 중요한 구성 요소를 사용합니다. 이 테이블은 볼륨의 모든 파일에 대해 최소한 하나의 항목을 포함하며, MFT 자체도 포함됩니다. 각 파일에 대한 중요한 세부정보, 예를 들어 크기, 타임스탬프, 권한 및 실제 데이터는 MFT 항목 내 또는 MFT 외부의 영역에 캡슐화되어 있으며, 이러한 항목에 의해 참조됩니다. 더 많은 세부정보는 공식 문서에서 확인할 수 있습니다.
SSL 키/인증서
#vol3 allows to search for certificates inside the registry
./vol.py -f file.dmp windows.registry.certificates.Certificates
악성코드
./vol.py -f file.dmp windows.malfind.Malfind [--dump] #Find hidden and injected code, [dump each suspicious section]
#Malfind will search for suspicious structures related to malware
./vol.py -f file.dmp windows.driverirp.DriverIrp #Driver IRP hook detection
./vol.py -f file.dmp windows.ssdt.SSDT #Check system call address from unexpected addresses
./vol.py -f file.dmp linux.check_afinfo.Check_afinfo #Verifies the operation function pointers of network protocols
./vol.py -f file.dmp linux.check_creds.Check_creds #Checks if any processes are sharing credential structures
./vol.py -f file.dmp linux.check_idt.Check_idt #Checks if the IDT has been altered
./vol.py -f file.dmp linux.check_syscall.Check_syscall #Check system call table for hooks
./vol.py -f file.dmp linux.check_modules.Check_modules #Compares module list to sysfs info, if available
./vol.py -f file.dmp linux.tty_check.tty_check #Checks tty devices for hooks
Yara로 스캔하기
이 스크립트를 사용하여 github에서 모든 yara 악성코드 규칙을 다운로드하고 병합하세요: https://gist.github.com/andreafortuna/29c6ea48adf3d45a979a78763cdc7ce9
rules 디렉토리를 만들고 실행하세요. 이렇게 하면 모든 악성코드에 대한 yara 규칙이 포함된 _malware_rules.yar_라는 파일이 생성됩니다.
wget https://gist.githubusercontent.com/andreafortuna/29c6ea48adf3d45a979a78763cdc7ce9/raw/4ec711d37f1b428b63bed1f786b26a0654aa2f31/malware_yara_rules.py
mkdir rules
python malware_yara_rules.py
#Only Windows
./vol.py -f file.dmp windows.vadyarascan.VadYaraScan --yara-file /tmp/malware_rules.yar
#All
./vol.py -f file.dmp yarascan.YaraScan --yara-file /tmp/malware_rules.yar
MISC
외부 플러그인
외부 플러그인을 사용하려면 플러그인과 관련된 폴더가 사용되는 첫 번째 매개변수인지 확인하세요.
./vol.py --plugin-dirs "/tmp/plugins/" [...]
Autoruns
https://github.com/tomchop/volatility-autoruns에서 다운로드하세요.
volatility --plugins=volatility-autoruns/ --profile=WinXPSP2x86 -f file.dmp autoruns
뮤텍스
./vol.py -f file.dmp windows.mutantscan.MutantScan
심볼릭 링크
./vol.py -f file.dmp windows.symlinkscan.SymlinkScan
Bash
메모리에서 bash 히스토리를 읽는 것이 가능합니다. .bash_history 파일을 덤프할 수도 있지만, 비활성화되어 있으므로 이 volatility 모듈을 사용할 수 있어 기쁠 것입니다.
./vol.py -f file.dmp linux.bash.Bash
타임라인
./vol.py -f file.dmp timeLiner.TimeLiner
드라이버
./vol.py -f file.dmp windows.driverscan.DriverScan
클립보드 가져오기
#Just vol2
volatility --profile=Win7SP1x86_23418 clipboard -f file.dmp
IE 기록 가져오기
#Just vol2
volatility --profile=Win7SP1x86_23418 iehistory -f file.dmp
메모장 텍스트 가져오기
#Just vol2
volatility --profile=Win7SP1x86_23418 notepad -f file.dmp
스크린샷
#Just vol2
volatility --profile=Win7SP1x86_23418 screenshot -f file.dmp
마스터 부트 레코드 (MBR)
volatility --profile=Win7SP1x86_23418 mbrparser -f file.dmp
**마스터 부트 레코드 (MBR)**는 저장 매체의 논리적 파티션을 관리하는 데 중요한 역할을 하며, 이는 다양한 파일 시스템으로 구조화되어 있습니다. MBR은 파티션 레이아웃 정보를 보유할 뿐만 아니라 부트 로더로 작동하는 실행 가능한 코드도 포함하고 있습니다. 이 부트 로더는 OS의 2단계 로딩 프로세스를 직접 시작하거나 (자세한 내용은 2단계 부트 로더 참조) 각 파티션의 볼륨 부트 레코드 (VBR)와 조화를 이루어 작동합니다. 심층적인 지식은 MBR 위키 페이지를 참조하십시오.
References
- https://andreafortuna.org/2017/06/25/volatility-my-own-cheatsheet-part-1-image-identification/
- https://scudette.blogspot.com/2012/11/finding-kernel-debugger-block.html
- https://or10nlabs.tech/cgi-sys/suspendedpage.cgi
- https://www.aldeid.com/wiki/Windows-userassist-keys * https://learn.microsoft.com/en-us/windows/win32/fileio/master-file-table
- https://answers.microsoft.com/en-us/windows/forum/all/uefi-based-pc-protective-mbr-what-is-it/0fc7b558-d8d4-4a7d-bae2-395455bb19aa
tip
AWS 해킹 배우기 및 연습하기:HackTricks Training AWS Red Team Expert (ARTE)
GCP 해킹 배우기 및 연습하기: HackTricks Training GCP Red Team Expert (GRTE)
HackTricks 지원하기
- 구독 계획 확인하기!
- **💬 디스코드 그룹 또는 텔레그램 그룹에 참여하거나 트위터 🐦 @hacktricks_live를 팔로우하세요.
- HackTricks 및 HackTricks Cloud 깃허브 리포지토리에 PR을 제출하여 해킹 트릭을 공유하세요.