분석 결과 요약
증거물 분석 결과를 간략히 요약한 페이지 입니다. 의뢰 내용 요약, 의뢰 내용과 기타 범행 입증 자료에 대한 결과를 제공합니다.
1.1 의뢰 내용 요약
의뢰 내용은 의뢰자(피해자)가 사건 현장에서 잠시 자리를 비우고, 복귀 후 해당 PC에 이상 프로세스(Economices)가 동작 중임을 의뢰자가 인지하였으며 이에 따라 해당 프로세스가 어디서 유입이 되었는지, 어떠한 기능을 하며, 추가적인 2차 피해가 발생할 수 있을 경우 대응 방안에 대하여 조사를 의뢰하였습니다. 자세한 내용은 아래와 같이 2개로 나뉩니다.
- 실행된 프로세스(Economices.exe)의 악성코드 여부
- 2차 피해 발생 가능성 여부와 대응 방안
1.2 해당 PC 악성코드 감염 사항
의뢰자의 PC에 대하여 해당 악성코드와 관련하여 분석 결과를 시간 순으로 나타내면 아래와 같습니다.
그림 1. 악성코드 행위 타임라인
- 피의자는 피해자가 자리를 비운 사이 2015-11-12 19:39:30에 피해자의 PC에 자신의 USB로 연결을 하였습니다.
- 연결 후 'eco'라는 폴더를 생성하였으며, 해당 디렉터리에 Economices.exe를 저장하고 실행하였으며, 이는 피해자의 키 이벤트 내용을 피의자의 PC로 전송하는 개인정보 침해를 유발하는 프로그램입니다..
- 실행 후 피의자는 피해자의 PC 레지스트리에 등록을 하여 지속적으로 피해자의 정보를 얻으려 하였다는 것을 알 수 있습니다.
- 이후 피의자는 2015-11-12 19:41:57에 USB 연결을 해제하였습니다.
2.증거 수집 및 분석 도구
증거 수집과 분석에 사용된 도구들의 이름과 버전, 그리고 각각 사용된 용도에 따라 정리를 한 페이지입니다.
2.1증거 수집 도구
증거 수집에 사용된 도구들에 대하여 정리하였으며 이러한 도구에 대한 내용은 아래의 [표–1]와 같습니다.
수집 도구 | 버전 | 제조사 | 다운로드 | 용도 |
DumpIt | v1.3.2.20110401 | MoonSols | http://www.moonsols.com/2011/07/18/moonsols-dumpit-goes-mainstream/ | 메모리 수집 |
REGA | 1.5.0.4 | 4&6Tech | http://forensic.korea.ac.kr/tools/rega.html | 레지스트리 수집 |
WinHex | 18.2.0.0 | X-Ways | http://www.x-ways.net/winhex/ | MFT 수집 |
FTK Imager | 3.3.0.5 | AccessData | http://accessdata.com/product-download | MFT 수집 |
표 1. 증거 수집 도구
2.2 분석 도구
분석 단계에서 사용한 도구는 아래 [표-2]와 같습니다.
도구 명 | 버전 | 다운로드 | 용도 |
REGA | 1.5.0.4 | http://forensic.korea.ac.kr/tools/rega.html | Registry분석 |
NTFS Log Tracker | 1.4 | https://code.google.com/p/ntfs-log-tracker/ | MFT 분석 |
Volatility | 2.3.1 | https://code.google.com/p/volatility/ | 메모리 분석 |
Rekall | 1.4.1 | https://github.com/google/rekall | 메모리 분석 |
Event Viewer | 10.0.10240.16384 | MicroSoft Windows | 이벤트 로그 분석 |
PEiD | 0.95 | https://tuts4you.com/download.php?view.398 | PE구조 분석 |
PE View | 1.10 | http://sourceforge.net/projects/peview/ | PE 구조 분석 |
HxD | 1.7.7.0 | http://mh-nexus.de/en/hxd/ | 바이너리 분석 |
Unpy2exe | . | https://github.com/matiasb/unpy2exe | Python Code 복구 |
Uncompyle2 | . | https://github.com/Mysterie/uncompyle2 | Python Code 복구 |
표 2. 증거 분석 도구
분석 단계에 있어서 Volatility와 Rekall을 통하여 수집한 메모리를 분석하려 했으나, 수집 단계나 이송에 문제가 있었는지 해당 YURI-PC-20151112-110112.raw 정상적으로 인식되지 않아 수집한 메모리를 통한 분석은 하지 못하였습니다.
3. 증거 수집
본 증거물은 의뢰자 PC로부터 2015-11-12 19:44:12부터 조사자의 USB를 연결하여 수집을 시작하였으며, 해당 의뢰자의 동참 하에 진행되었습니다. 그리고 각 분석의 진행을 시간 순으로 정렬한 내용은 아래와 같습니다.
그림 2. 증거 수집과 이송 절차
증거물 수집 과정에 있어 고려해야 할 사항은 다음과 같습니다.
- 의뢰자의 인터뷰
- 전체적인 이미징은 거부함에 따라 선별적인 증거 수집
- 압수 수색이 아니기에 의뢰자가 동의한 사항에서만 증거 수집
- 증거 수집에 있어 의뢰자가 동참하였으며 해당 의뢰자의 요청으로 인하여 지정된 수준까지만 수집이 가능
- 의뢰자는 증거 수집이 끝난 후 본인의 작업(LoL)을 해야 함에 따른 시간 상의 제약이 존재
* 증거 수집에 있어 해당 PC의 메모리 수집이 올바르게 되지 않았기에 해당 프로그램에 대하여 추가적인 분석을 위하여 의뢰자에게 해당 PC의 Economices.exe를 전송해줄 것을 요청하였고 15-11-13 03:41:50 해당 파일을 수신하였습니다.
3.1 증거물 대상과 수집 PC 환경
수집 대상에 대하여 충분한 설명을 의뢰자에게 하였으며 이에 따른 동의가 있고 증거 수집을 하였기에 선별적인 증거 수집이 이루어졌으며, 의뢰자가 수집에 동의한 사항은 아래의 표와 같습니다.
증거 수집 대상 | |
메모리 | 레지스트리 |
이벤트 로그 | $MFT |
표 3. 증거 수집 대상
분석 대상 컴퓨터 환경에 대한 기본 정보는 아래의 표와 같습니다.
대상 PC 환경 | |
운영체제 | Windows7 Ultimate K |
서비스 팩 | Service Pack 1 |
프로세서 | Intel® Core™ i5-4570 CPU @ 3.20 GHz |
메모리 | 8.00GB |
시스템 종류 | 64비트 운영체제 |
표 4. 증거 수집 대상 PC 환경
3.2 증거 메모리 수집 : 2015-11-12 19:45:27
메모리 수집에 있어 DumpIt을 통하여 디스크의 변질을 최소화 하기 위하여 조사자의 외부 USB로 메모리 수집을 진행하였으며 YURI-PC-20151112-110112.raw로 저장이 되었습니다.
DumpIt - 19:45:27 |
Address space size : 9110028288 Bytes ( 8688 Mb ) Free space size : 14673256448 Bytes ( 13993 Mb) Destination: \??\G:\Ghost\Tool\forensic_tool\DumpIt\YURI-PC-20151112-110112.raw SHA-1 : 86d99e1e756c90d34f5f27253d986b98a2974955 |
3.3 증거 레지스트리 수집 : 2015-11-12 20:12:03
REGA를 통한 레지스트리 수집을 하였으며 수집된 레지스트리 파일은 아래의 [표-5]와 같으며, 이렇게 수집된 레지스트리에 대한 해시와 시간은 [별첨-1]을 통하여 확인할 수 있습니다.
수집된 레지스트리 관련 자료 | ||
Amcache.hve | COMPONENTS | DEFAULT |
Default User.NTUSER.DAT | Default.NTUSER.DAT | SAM |
SECURITY | SOFTWARE | SYSTEM |
YuRi.NTUSER.DAT | YuRi.USRCLASS.DAT | Setupapi.app.log |
표 5. 수집된 레지스트리 관련 자료
3.4 증거 PC의 $MFT 수집 : 2015-11-12 20:18:34
FTK Imager와 WinHex를 통하여 $MFT와 $LogFile, $J 파일을 수집하였으며, 이 파일에 대한 해시 값은 아래와 같습니다.
File | Size | SHA-1 Hash |
$J | 1.58GB | 8a8f8d00d8ad417d60cfece9ba835c341d728f4a |
$LogFile | 64.0MB | 38101525002df66985afca4e5c0cbb8b973f96f8 |
$MFT | 295MB | dfbe0ec0bbcf3ec9fdfacf44516429dd0ab34d39 |
표 6. MFT파일 크기와 해시 값
3.5 의뢰자에게 별도로 받은 의심 파일 : 2015-11-13 03:41:50
해당 의심 파일이 의뢰자에 PC에 남아있음을 인지하였으며 이에 대해 의뢰자에게 송신해줄 것을 요청하였으며, 이러한 요청에 의해 2015-11-13 03:41:50에 해당 파일을 송신하였습니다. 파일에 대한 내용은 아래의 표와 같습니다.
Economices.exe | |
Size | 8.85 MB |
SHA-1 | BC6D28E10CAA9508175F25F97A549C1C02F28067 |
표 7. Economices.exe의 크기와 해시 값
해시 값을 통하여 전송한 파일과 수신한 파일 간에 무결성이 유지되었음을 확인할 수가 있었습니다.
4. 상세 분석 내용
상세 분석 내용을 제공하는 페이지 입니다. 의뢰자의 PC에서 수집한 증거를 분석실로 이송 후 조사자의 분석 환경에 해당 증거들을 옮긴 후 분석을 진행하였습니다.
4.1MFT 분석을 통한 시간대 확인
의심되는 프로세스(Economices.exe)에 대한 타임스탬프를 확인할 것이며. 사건 현장은 상대적으로 의뢰자의 지인이 많이 찾아오는 장소로 동 시간대에 의뢰자가 잠시 자리를 부재한 사이(19:35:00-19:43:00)에 발생한 것임을 고려하여야 합니다.
이를 토대로 근처 시간대를 확인할 것이며 해당 시간대에 의심되는 파일이 생성되거나 실행되었는지를 확인하기 위하여 MFT를 분석해 보았습니다.
그림 3. MFT 분석
위의 그림과 같이 해당 프로그램은 "\Documents\카카오톡 받은 파일"에' eco폴더를 생성 후(19:40:12) 해당 경로에 저장(19:40:14)이 되었다는 것을 확인할 수가 있습니다. 이에 대한 csv파일은 [별첨-3]과 [별첨-4]에서 확인할 수 있습니다.
이를 통해 의뢰자가 자리를 비우고 약 5분이 지난 후 제 3자에 의해 해당 파일이 생성되었음을 알 수가 있습니다.
4.2 해당 프로그램 침입 경로 확인
위의 MFT 분석을 통해 시간대를 축소할 수가 있었으며, 이러한 시간에 이루어진 레지스트리 변경사항에 대하여 분석해보았습니다.
그림 4. USB 연결 흔적 확인
그림-4과 같이 해당 시간(19:39:30)에 USB와 연결한 흔적들을 확인할 수가 있었으며 이를 통해 해당 프로그램이 USB를 통하여 복사되었음을 예상할 수가 있습니다. 하지만 여기서 최초 장비 연결 시 더 많은 레지스트리의 값이 변화하는데 몇 개의 값만이 변화되었기에 해당 USB는 이번이 최초 연결이 아님을 알 수가 있습니다.
이는 그림-5를 보면 알 수 있듯이 해당 필드의 한 칸 상위인 VID_058F&PID_6366의 값은 마지막으로 쓰여진 값이 2015-10-04 03:11:47인 것을 통해 해당 일자에 최초로 PC에 연결이 되었으며 이번이 최초연결이 아님을 알 수가 있습니다.
그림 5. VID_058F&PID_6366 LastWriteTime
이를 통해 해당 프로그램 Economices.exe를 설치한 피의자는 의뢰자의 지인임을 예상할 수가 있었으며, 여기에 사용된 USB의 정보는 아래의 표와 같습니다.
VID | 058F |
PID | 6366 |
Serial | 058F6366438 |
Volume GID | b8017014-5631-11e5-ac07-d0509901c143 |
Manufacturer | Multiple |
Product Model | Card Reader |
Product Revision | 1.00 |
Device Vendor | Generic |
Device Name | Mass Storage Device |
Device Revision | 0100 |
표 8. 악성코드 유입에 사용된 USB의 정보
해당 USB에 대한 사용 흔적은 수집한 대상 PC의 DriverFrameworks-UserMode 이벤트 로그에도 기록되었는데, 이에 대해 표-8을 보면 19:39:32에 연결하였다는 항목을 보아 위 그림-4과 그림-5에서의 내용에 신빙성을 더해주며, 해당 USB의 연결 해제가 19:41:57에 이루어졌다는 것 또한 확인을 할 수가 있습니다. 자세한 사항은 [별첨-5]를 통해 확인할 수 있습니다.
표 9. 증거 대상
4.3 기타 침해 입증 자료
아래의 그림과 같이 해당 파일의 경로와 해당 Economices.exe가 레지스트리에 추가된 것(19:41:33)을 확인할 수가 있으며 이는 USB를 연결 해제(19:41:57)하기 전에 등록된 것임을 알 수가 있으며, 값이 추가되었다는 것은 컴퓨터를 종료 후 다시 실행할 때마다 해당 프로그램이 자동 실행되는 것을 의미하며 이는 악성코드가 지속성을 유지하고자 할 때 주로 쓰는 방법입니다.
그림 6. 지속성 유지를 위한 레지스트리 추가
그림-7과 같이 해당 프로그램은 19:40:47에 실행이 된 것임을 확인할 수가 있습니다.
그림 7. Economices.exe 실행 시간
대상 PC의 증거를 수집하며 네트워크 연결 상태도 확인을 해보았으며 이에 대한 사진은 [별첨-6]을 통해 볼 수 있고, 이를 토대로 중요한 사항인 3226(Economices.exe)은 현재 같은 IP 영역대인 192.168.0.5와 네트워킹을 하고 있었음을 알 수가 있습니다.
Protocol | Local Address | Foreign Address | State | PID |
TCP | 192.168.0.3:51010 | 192.168.0.5:7222 | ESTABLISHED | 3226 |
표 10. Netstat을 통해 본 연결 상태
이를 통하여 해당 프로그램은 같은 IP에 있는 의뢰자의 친구 김00씨의 PC가 연결된 주소로, 2대의 PC가 네트워킹을 하고 있음을 알 수가 있으며 이러한 악성코드의 기능은 아래에서 설명하겠습니다.
4.4 해당 프로세스의 악성코드 여부 확인
Economices.exe에 대한 상세한 분석을 진행하는 페이지입니다. 해당 파일에 대한 PE구조를 분석하고 그에 맞게 분석을 진행하였습니다.
그림 8. PEiD의 출력 결과
위의 그림과 같이 PEiD를 통하여 보았을 때는 별로 알 수 있는 유용한 내용이 없었으며 추가적으로 PE 구조를 더 살펴본 결과 .rsrc 섹션에 아래의 그림과 같이 PYTHON27.DLL이라는 문자열과 exe의 MZ 헤더와 PE 시그니처 등이 존재하는 것을 확인할 수가 있으며, 이러한 구조는 주로 Python으로 된 코드를 py2exe를 통하여 컴파일 했을 경우 주로 나타나는 구조임을 알 수가 있습니다.
그림 9. 해당 파일의 리소스 섹션
이를 통하여 Py2exe된 파일을 다시 코드로 볼 수 있도록 제작하는 작업이 필요하며 사용된 도구는 [표-2]에 기재된 바와 같이 2개의 Python Code를 통하여 진행하였습니다. 해당 과정은 아래와 같습니다.
그림 10. Python Code 복구 과정
이러한 과정을 통하여 복구된 파이썬 코드는 [별첨-7]와 같으며 이를 통해 파이썬의 기능에 대하여 알아보았습니다. 주요 기능은 아래와 같습니다.
- Pyhook을 통해 키로깅의 기능을 구현하였습니다.
- 의뢰인의 지인이였던 김00군 PC의 IP 주소인 192.168.0.5가 나타나있습니다.
위 두가지 사실을 종합해보았을 때 해당 프로그램은 키로깅의 기능이 있으며 하나의 클라이언트로 동작하는 것을 확인할 수가 있었습니다. 이를 통해 의뢰인(192.168.0.3)은 김00군(192.168.0.5)에 키 이벤트를 전송하므로 개인 정보 유출의 위험이 많다는 것을 알 수가 있습니다.
그림 11. 메모리 분석을 통한 키로깅 확인
5. 대응 방안
위의 분석을 토대로 2차 피해 발생에 대응하기 위한 방안은 다음과 같습니다.
- 실행 중인 악성코드의 경우 해당 프로세스를 종료하여 추가적인 피해를 방지해야 합니다.
- 현재 피해자의 PC에 악성코드가 지속성을 유지하고 있기 때문에 해당 레지스트리의 값을 제거하여 2차적인 피해를 방지합니다.
- 피의자가 피해자의 관계 상 해당 프로세스를 다시 설치할 수가 있기에 피해자의 PC에 접근을 하지 못하게 하는 등 제약이 필요합니다.
'Forensic > Analysis' 카테고리의 다른 글
NTFS & Python - $MFT Acquisition (0) | 2016.01.07 |
---|---|
노트북 하드 컴퓨터 연결 (2) | 2016.01.03 |
Tigger Memory Analysis (0) | 2015.12.26 |
Black Energy 메모리 분석 (0) | 2015.12.17 |
Memory Analysis - CoreFlood (0) | 2015.12.05 |