공부정리
-
[02-11 공부정리(Chaining RTL 정리)]공부정리 2018. 2. 11. 01:10
오늘은 protostar Stack6~7번을 풀었다.6번은 RTL을 7번은 Chaining RTL을 이용해서 풀었다.7번같은 경우는 ASLR이 걸려있는 상황이라면 ROP를 이용해야 하는 문제였다.내일은 ASLR이 걸려있는 상태라고 가정하고 ROP로 문제를 풀어볼 생각이다. 자 그럼 오늘 공부한 부분들을 정리하도록 하겠다. [Chaining RTL] RTL공격을 할때 System( )뒤에 dummy값으로 "AAAA"를 준 적이 있다.RTL 정리할 때도 말했지만 dummy값 부분은 의미없는 부분이 아니다.system( )가 끝나고 복귀할 주소가 저장되어 있는 공간이다.하지만, 우리는 /bin/sh을 따내면 그 뒤 상황은 어디로 복귀하던 상관이 없기에 "AAAA"라는 dummy값을 준 것이다. Chaining..
-
[02-10 공부정리]공부정리 2018. 2. 10. 03:09
오늘은 tuts4you에 Lena Tutorial 문제를 풀었다.1번 문제를 풀었는데 1번문제의 write up하는 형식의 글로 쓰도록 하겠다. 우선 tuts4you 사이트는 여기다.[tuts4you Site] .rar의 압축파일이며, 비밀번호는 tuts4you다.압축을 풀고 file폴더에 들어가면 [File]기본적인 참고문서들과 함께 우리가 리버싱할 reverseMe.exe 파일이 있다.거두절미하고 실행부터 해보자! [reverseMe 실행]실행을 하면 "Evaluation period out of date. Purchase new license" 라는 창이 하나뜨고확인을 누르면 종료된다.뭐 평가기간이 만료되었으니 새로운 라이센스를 구매하라는 글인데..실행으로 얻을 수 있는 정보는 없으니 ollyDBG..
-
[02-08 공부정리(RTL정리)]공부정리 2018. 2. 8. 03:32
오늘은 RTL에 대해서 공부했으니, 실습한 부분은 정리하겠다. [RTL이란?]Return To Library로 프로그램 ret(리턴 값)에 공격자가 원하는 라이브러리 함수 주소를 로드 시켜해당 라이브러리 함수를 실행하는 공격기법이다. 예를들면 System함수를 호출한다거나 또, System함수를 호출한다거나... 맞다. 우린 쉘을 따면 된다.또, RTL공격은 메모리 보호 기법중 NX Bit와 DEP를 우회한다.NX bit(Never Execute bit) : ELF 보호기법. NX특성으로 모든 메모리영역을 데이터 저장용도로만 사용한다. 따라서 쉘코드 실행을 방지한다.DEP(Data Execution Prevention) : PE 보호기법. 데이터 실행 방지로 스택이나 힙에서 쉘코드 실행을 방지한다. 간단..
-
[02-07 공부정리]공부정리 2018. 2. 7. 00:37
2018-02-06 공부정리 시작!오늘은 [리버싱 핵심원리]에서 스택부분을 공부했다.또, Google Codejam_Africa문제 중 [Odd Man Out] 문제를 풀었다. [Stack Memory] 프로세스에서 스택 메모리 역할은 다음과 같다.- 지역변수 저장- 함수 호출 시, 파라미터 전달- 복귀주소(Return Address) 저장 또한, 스택 메모리는 FILO(First In Last Out)구조로 되어있는데말 그대로 선입후출. 먼저 PUSH된 데이터는 제일 마지막에 POP되는 구조다. 스택을 관리하기 위해서 두개의 레지스터가 사용되는데ESP와 EBP가 그것이다.ESP는 Stack Pointer이며, 스택의 제일 위쪽을 가르키고 있다.(낮은주소)EBP는 Base Pointer로 스택 제일 바닥..
-
[02-06 공부정리]공부정리 2018. 2. 6. 01:41
2018-02-05 오늘 하루 공부한 것을 정리한다. 오늘은리버싱 핵심원리(나뭇잎 책)을 보면서 공부를 진행했다.내 분야를 탐색하는데 시간이 오래걸렸다.시스템도 재밌고, 네트워크 또한 재밌게 느껴졌다. 웹도 그러했고. 그러다 리버싱을 한번 경험해봤는데 너무 재밌었다!정확히 말하면 포너블 문제를 풀기위해 리버싱을 하는 과정이었는데포너블과 리버싱은 숟가락과 젓가락같은 관계라고 생각했기 때문에둘 중 리버싱을 좀 더 집중적으로 공부해보기로 마음먹었다.앞으로 공부는 [리버싱 핵심원리]로 진행할 것이다. 오늘은 1장~5장까지 공부했다.리버싱이 무엇인지 부터해서 HelloWorld.exe 메인함수 찾기, 디버거 사용법, 바이트오더링, IA-32 레지스터 까지 말이다. 우선 HelloWorld.exe에서 메인함수를 찾..