기본 콘텐츠로 건너뛰기

힘내라 청춘. 20171113

Windbg-windows-kernel-debugging

VMware 윈도우즈 커널 디버깅 환경 설정 윈도우즈 커널 디버깅을 위해 VMware를 활용해보자. 1) 호스트 PC에 Windbg를 설치한다. 검색엔진에서 Windbg 설치 를 검색하면 쉽게 마이크로 소프트 페이지를 찾을 수 있다. 설치 프로그램을 다운받아 설치를 진행한다. 2) 가상 머신의 전원을 끈 후 VM > Settings > Add > Serial Port 를 선택하여 Serial Port를 추가한다. 생성 시 Output to named pipe 옵션을 선택하고 \\.\pipe\[이름 지정] 의 형식으로 Name Pipe를 설정한다. 3) 가상 머신의 전원을 켜 C:\boot.ini 파일을 생성한다. [boot loader] timeout = 30 default =multi (0) disk (0) rdisk (0) partition (1) \ WINDOWS [operating systems] multi ( 0 )disk( 0 )rdisk( 0 )partition( 1 )\ WINDOWS = "Microsoft Windows XP Professional" /fastdetect /debugport= COM1 /baudrate= 115200 4) 호스트 PC에서 명령 프롬프트 실행 후 Windbg 설치 디렉터리로 이동한다. windbg.exe" -k com:port=\\.\pipe\[지정한 이름],baud=115200,pipe,reconnect 명령어를 실행하여 연결을 기다린다. 5) 가상 머신을 재시작하면 호스트 PC의 Windbg에서 연결에 성공한 것을 확인할 수 있다. 6) Break( Ctrl + Break ) 버튼 선택 시 디버그 모드가 동작한다. 7) File > Symbol File Path 를 선택하여 심볼을 설정한다. SRV *c :\symbols *http : //msdl .microsoft.com/download/symbols 웹 심볼...

Open-Redirect

피싱 사이트 이동 시키기 1. BASIC 인증 요청 양식 활용 시나리오 BASIC 인증 양식을 이용하여 피싱 사이트로 이동 코드 공격 포인트 : 원본 URL 뒤 http: //www .example .co .kr @www .attacker .com 환경 원본 URL 뒤에 인자 값을 이어붙일 수 있는 경우 내용 BASIC 인증 URL 요청 양식(ex. http://ID:PW@www.example.co.kr )을 이용하여 원본 URL을 무시하고 피싱사이트로 이동 2. IPv6 요청 양식 활용 IPv4, Domain 양식의 피싱 URL 완성이 힘들 때 시나리오 IPv6 URL 요청 구문과 조합하여 피싱 사이트로 이동 코드 공격 포인트 - 원본 URL 앞 http:// [ 0:0:0:0:0:0:0:1 ]#.example.co.kr http:// [ 0:0:0:0:0:0:0:1 ]?.example.co.kr 환경 서브 도메인 값 조작 가능한 경우 javascript, 점(.)을 체크하는 경우 (ex [pram].example.co.kr 로 이동 목적) 내용 javascript:function(), attacker.co.kr, xxx.xxx.xxx.xxx 안될 때, 한 번쯤 시도

Sulley-2

Sulley - 2 Savant는 윈도우용 오픈소스 웹 서버로 버전 별로 여러 알려진 취약점이 존재한다. Savant 3.0에는 Buffer Overflow 취약점이 존재하는 데, 이를 Sulley 퍼저를 이용하여 퍼징 테스트를 하겠다. 먼저 Savant 3.0 을 설치한다. http 프로토콜은 Sulley 퍼저에 기본적으로 내장되어 있으므로 이를 불러와 사용해도 괜찮다. 우리는 이미 알려진 취약점 에 대해서 퍼징 테스트를 수행하므로 편의상 취약 요소를 겨냥한 테스트를 진행한다. requests/http.py from sulley import * s_initialize( "HTTP" ) s_group( "verbs" , values=[ "GET" , "READ" , "POST" , "TRACE" ]) if s_block_start( "body" , group= "verbs" ): s_delim( " " ) s_delim( "/" ) s_string( "index.html" ) s_delim( " " ) s_string( "HTTP" ) s_delim( "/" ) s_string( "1" ) s_delim( "." ) s_string( "1" ) s_static( "\r\n\r\n" ) s_block_end( "body" ) httpfuzz.py from sulley import * from requests import http def init_message (sock) : init = 'GET /index.html HTML/...

Remove-Server-Header

응답 메시지 내 서버 버전 정보 제거 1. Apache 1) 조치 방법 “/etc/htpd/conf/httpd.conf” 파일 안에서 1. ServerTokens OS → ServerTokens Prod 2. ServerSignature On → ServerSignature Off 로 변경한 후 아파치를 재시작하면 헤더 값의 아파치 버전 정보 및 OS 정보를 제거할 수 있다. 2) 참고 URL http://zetawiki.com/wiki/CentOS_ 아파치_보안권장설정_ServerTokens_Prod,_ServerSignature_Off 2. IIS 1) 조치 방법 IIS 6.0 urlscan_setup 실행. 설치. \windows\system32\inetsrv\urlscan\urlscan.ini 파일을 열어 다음 수정(RemoveServerHeader=0 을 RemoveServerHeader=1 로 변경) 서비스에서 IIS Admin Service 재시작. IIS 7.0 IIS 관리자를 열고 관리하려는 수준으로 이동합니다. 기능 보기에서 HTTP 응답 헤더를 두 번 클릭합니다. HTTP 응답 헤더 페이지에서 제거할 헤더를 선택합니다. 작업 창에서 제거를 클릭하고 예를 클릭합니다. 2) 참고 URL IIS 6.0 : http://gonnie.tistory.com/entry/iis6- 응답헤더-감추기 IIS 7.0 : https://technet.microsoft.com/ko-kr/library/cc733102(v=ws.10).aspx 3. jetty 1) 조치 방법 “jetty.xml” 파일에서 jetty.send.server.version=false 설정 2) 참고 URL http://attenuated-perspicacity.blogspot.kr/2009/09/jetty-61x-hardening.html 4. Nginx ...

Sulley-1

Sulley Sulley 는 파이썬으로 개발된 퍼저로 많은 사용자를 보유한 인기있는 도구이다. Gray Hat Python이나 인터넷의 여러 블로그에서 쉽게 사용법을 찾아볼 수 있어 퍼징 입문을 위해 많이 활용되고 있으며 파이썬으로 개발된 덕분에 커스터마이징을 위한 기본 뼈대로도 사용되고 있다. Wiki 페이지 를 통해서 설치방법을 제공해주고 있으나, 진행 도중 설치 에러로 막히는 경우가 많다. 이는 컴파일 관련 문제로 Microsoft Visual C++ Compiler for Python 2.7 설치 후 “Visual c++ command prompt”를 이용하여 진행하면 대부분 해결 가능하다. 튜토리얼로 사용되는 warftpd 1.65 퍼징 테스트를 진행해보자. ftp.py 퍼징 테스트를 위해서 FTP 통신 표준 데이터 정의가 필요하다. request 폴더 밑에 ftp.py 파일을 생성하고 아래 코드를 입력하자. from sulley import * s_initialize( "user" ) s_static( "USER" ) s_delim( " " ) s_string( "justin" ) s_static( "\r\n" ) s_initialize( "pass" ) s_static( "PASS" ) s_delim( " " ) s_string( "justin" ) s_static( "\r\n" ) s_initialize( "cwd" ) s_static( "CWD" ) s_delim( " " ) s_string( "c:" ) s_static( "\r\n" ) s_initialize( "dele" ) s_static( "DELE...

Hooking-1

Hooking - 1 후킹이란 운영 체제나 응용 소프트웨어 등의 각종 컴퓨터 프로그램에서 소프트에어 구성 요소 간에 발생하는 함수 호출, 메시지, 이벤트 등을 중간에서 바꾸거나 가로채는 명령, 방법, 기술이나 행위를 말한다. 출처: 위키피디아 키보드 후킹 소스코드를 살펴보며 후킹에 대해 이해해보자. void Stealth() { HWND Stealth; AllocConsole(); Stealth = FindWindowA( "ConsoleWindowClass" , NULL); ShowWindow(Stealth, 0 ); } 후킹 소스에서 공통적으로 볼 수 있는 형태의 로직으로 이는 콘솔 프로그램 실행 시 콘솔 창을 드러내지 않고 동작시키는 내용이다. 사용된 함수 하나 씩 살펴보자. BOOL WINAPI AllocConsole(void): 호출 프로세스에 새로운 콘솔을 할당하는 함수로 실패 시 Zero를 반환한다. MSDN HWND WINAPI FindWindowA( In_opt LPCTSTR lpClassName, In_opt LPCTSTR lpWindowName ); ClassName과 윈도우 명이 일치하는 경우 윈도우 핸들을 가져온다. 실패 시 NULL을 반환한다. MSDN BOOL WINAPI ShowWindow( In HWND hWnd, In int nCmdShow ); 윈도우 보여주기 상태를 설정한다. SW_HIDE: 0 으로 설정 시 창을 숨기고 다른 창을 활성화한다. 이제 이번 예제의 핵심 함수 GetAsyncKeyState() 와 GetKeyState() 를 살펴보자. SHORT WINAPI GetAsyncKeyState( In int vKey ); 가상 키코드 를 인자로 하여 함수가 호출되는 시점에 키를 누르고 있는지 아닌지와 이전에 누른적이 ...