HKCert CTF Forensic - Wheres the APT Attack 3 Guide
HKCert CTF Forensic - Q3: Where’s the APT Attack? APT攻擊在哪裡? Hidden Flag? 隱藏旗?
Info
- Author: Nightsedge
- Categories: forensics
- Hidden Question!
Question Description (zh-HK)
請以第2題繼續。
您是高級網絡安全分析師。
您的經理要求您協助分析Windows內存映像,作為我們目前調查的一部分。
這臺受害機器已經被隔離,Windows內存映像已經被提取供您調查。
預計內存映像將揭示一個包含命令和控制(C2)進程的常見程序,通常被稱為信標 (beacon)。
隱藏旗。如果大神您找到的話請跟在下交流一下IR心法,
Question Description (en)
Please continue from Q2.
You are the Senior Cybersecurity Analyst.
Your Manager is requesting your assistance in analyzing a Windows memory image as a component of our current investigation.
This victim machine has been isolated and the Windows memory image has been extracted for your review.
The memory image is expected to reveal a routine that includes a command and control (C2) process, commonly known as a beacon.
There is a hidden flag! It will be great to contact me if you can find it, you should be very great in IR.
Steps
- Review the C# DLL program from Q2
- Guess the command and control (C2) framework
- Read Didier Stevens’s articles from SANS (Strongly Recommended)
- Decrypt and Parse the beacon file, and get the Cobalt Strike beacon setting profile
Warning
- Real Malware
- Can bypass Anti-Virus Solutions
- Almost no signature? maybe not?
- Not useful: malfind (because no signature), yarascan (or you have your own great Yara signature)
- The author (me) is too lazy to tidy up the write-ups~
Guide
1. Review the C# DLL program from Q2
The mpclient.dll
called the MsMpEng.dll
function StartW
which is common export function from Cobalt Strike DLL stage/stageless beacon.
data:image/s3,"s3://crabby-images/a0e28/a0e28a94fd22f421c6e3b7422a1175b8d6124ea7" alt="1.mpclient_main"
2. Extract profile using Sentinel-One’s CobaltStrikeParser?
Sorry, no matched starting point.
Because the shellcode is encrypted with an unknown XOR key. =]
1 | python3 ./parse_beacon_config.py file.0xd88e42603e00.0xd88e4045bc70.ImageSectionObject.MsMpEng.dll.img |
data:image/s3,"s3://crabby-images/348e0/348e05794b1501d66c4be679337ee0a64cdec66c" alt="2.failed_CobaltStrikeParser"
3. Analysis of an Encoded Cobalt Strike Beacon by Didier Stevens
This very great article by Didier Stevens:
https://isc.sans.edu/diary/Analysis+of+an+Encoded+Cobalt+Strike+Beacon/29014
Strongly recommended to read the article again!
Follow this article’s ideas and steps to continue your analysis.
XOR known plaintext attacks!
Use option -g o
(o = overlay) to extract the overlay, and -g s
(s = stripped) to extract the PE file without overlay.
1 | python3 pecheck.py file.0xd88e42603e00.0xd88e4045bc70.ImageSectionObject.MsMpEng.dll.img -g s -D | python3 xor-kpa.py -n cs-key-dot |
data:image/s3,"s3://crabby-images/f5a96/f5a9656bb98ef35d830b88785e19d166ed96e643" alt="3.1.Analysisbeacon"
Now you can find the meanful strings, some windows API calls and file names.
data:image/s3,"s3://crabby-images/765da/765da10ccdfdead1d9d3bf8f11f9c3f67f406b31" alt="3.2.decoded_meanfulstrings"
4. Extract the Cobalt Strike profile and pretty print the beacon profile
1 | python3 pecheck.py file.0xd88e42603e00.0xd88e4045bc70.ImageSectionObject.MsMpEng.dll.img -g s -D | python3 xor-kpa.py -n cs-key-dot -d > cobaltstrike.sample |
data:image/s3,"s3://crabby-images/96e08/96e08b34ae71881b7d9683463e5c9fd12f9345ae" alt="4.extractprofile"
5 Flag from profile
data:image/s3,"s3://crabby-images/c5cfc/c5cfcb1f2932aac8d68a3c1bd4515fe1f6b544fd" alt="5.1.profileflag"
data:image/s3,"s3://crabby-images/9790f/9790f30e00751b7c7d51fe18391255fffef2e184" alt="5.2.flag"
Flag
1 | hkcert24{4p7_4774ck_50154_c0b4l7_57r1k3_pr0f1l3_3x7r4c73d!} |