동글동글 라이프
1.시작하며... 본문
안녕하세요 h0ney 입니다!
이번 강좌에 설명할 내용은 레지스트리 Hive 파일 포멧 분석기(Registry Hive File Format Analyzer) 입니다.
사이버 포렌식에서 Registry Hive 파일 분석은 선택이 아니라 필수일 정도로 중요도가 높습니다.
이를 프로그래밍 도구를 만들면서 전체 구조를 파악하며 공부하는 글을 적어보려고 합니다.
프로그래밍 분석에 사용될 언어는 perl 이며 Windows Forensic Analysis의 regpl.pl 을 참고하여 설명드리겠습니다.
보안 공부를 할때 기본적으로 배우는 개념 중 PE 구조 라는 것이 있습니다.
(PE구조란 윈도우 운영체제에서 지원되는 실행 파일의 형식을 뜻하며 실행을 할 수 있는 구조를 가진 파일입니다. )
이런 PE구조를 분석 및 공부를 하려면
PE구조에 관련된 서적을 열심히 읽어야 하는데
책을 아무리 읽어도 16진수가 난무하는 알 수 없는 값들 때문에
눈꺼플이 무거워지고 꾸벅꾸벅 잠만 쏟아집니다 ^^;;
PE구조 같은 파일구조를 공부하기에 좋은 방법을 소개하자면
첫 번째로는 샘플 파일을 Hex Editor를 통해 직접 값들을 확인하며 공부하는 방법.
두 번째로는 파일에 관련된 도구를 직접 사용해서 내부 구조를 확인하는 방법
세 번째로는 프로그래밍으로 직접 파일구조 분석 도구를 만들어 보는 방법입니다.
Hex Editor 나 도구를 이용해서 구조를 확인하고 넘어가도 상관이 없지만
도구를 직접 만들어 본다는 것만으로 설레이지 않나요?? ㅎㅎ
좋은 점에 대해서 부연 설명을 드리자면...
1. 분석도구를 만드려면 파일 구조가 온전한지 값이 잘 출력되는지
테스트를 하며 만들어야 하기 때문에 자연스럽게 파일구조가 머릿속에서 그려집니다.
2. 책에서 봤던 혹은 알고있는 내용과는 다르게 다양한 변수들이 많이 생기는데
이런 변수들을 하나하나 해결할 수록 단단한 내공이 쌓여지게 됩니다.
3. 파일의 구조를 생성하는 것에 대한 알고리즘을 알게되어 다른 형식의 파일을 접하더라도
쉽게 이해할 수 있는 지식도 생기게 되죠!!
도구로 만들고 싶다는 생각이 불쑥불쑥 솟아 나시죠??!!
레지스트리 Hive 파일 분석기를 잘 만들어 두면 레지스트리 값들을 모두
얻을 수도 있고, 지워진 레지스트리 값도 복구가 가능하기 때문에
많은 분야로 확장 가능할 것이라 생각됩니다.
강좌는 아래와 같이 2가지로 나누어서 진행하려고 합니다.
1. perl을 이용하여 내부 값들을 알아보며 각각의 키와 값들을 뽑아내어 보는 파트
2. C#을 이용하여 UI를 꾸며 분석도구를 만들어가는 파트
두 파트 모두 도구는 만들어져 있으니 어떻게 설명하느냐가
중요할 것 같습니다.. 부담이 되네요 ㅡ_ㅠ
모르는 부분도 많으니 피드백 주시면 감사하겠습니다 ^^/
준비물
1. Perl 설치 ( 링크를 참고 하시면 됩니다 ^^ 이럴때 카페 홍보!! )
2. Registry Hive File 문서 ( 문제가 될 시 삭제 하겠습니다.)
The WindowsNT Registry File Format.pdf
FORENSIC ANALYSIS OF UNALLOCATED SPACE.pdf
3. Windows Forensic Analysis의 perl 소스코드
4. Hex Editor - ICY Hexplorer ( 제가 좋아하는 Hex Editor 입니다 )
5. 끝없는 열정!
'개발자 이야기 > [forensic]Winproof' 카테고리의 다른 글
3. Bin Header (2) | 2012.04.05 |
---|---|
2. Registry hive structure (1) | 2012.04.04 |
Detail (Web Log Analysis) (1) | 2010.07.28 |
Detail (Registry Analysis) (2) | 2010.07.28 |
Detail ( Main UI ) (1) | 2010.07.28 |