기본 콘텐츠로 건너뛰기

10월, 2017의 게시물 표시

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 ); 가상 키코드 를 인자로 하여 함수가 호출되는 시점에 키를 누르고 있는지 아닌지와 이전에 누른적이

코세라 Software Security 과정 수료

CVE-2017-12623

CVE-2017-12623 Apache NIFI 에서 XXE 취약점이 발생하여 조치되었다. 취약 코드와 조치 후 코드를 비교해보자. 취약 코드 final Unmarshaller unmarshaller = JAXB_CONTEXT.createUnmarshaller(); unmarshaller.setSchema(schema); - final JAXBElement<Authorizers> element = unmarshaller.unmarshal( new StreamSource(authorizersConfigurationFile), Authorizers.class); external entity 제한 없이 XML 파일을 불러와 사용하여 external entity에 삽입된 악의적인 명령을 수행하는 취약점이 발생하였다. 테스트 파일 + <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <!DOCTYPE object [<!ENTITY xxe SYSTEM "file:///etc/passwd" >]> + < object > + < name > &xxe; </ name > + < description > Arbitrary XML that has an XXE attack present. </ description > + < groupId > 3a204982-015e-1000-eaa2-19d352ec8394 </ groupId > + < timestamp > 09/05/2017 14:51:01 PDT </ timestamp > + </ object > 취약

lena-tutorial-3

lena tutorial 3 lena tutorial 3은 잔소리 메시지 창을 제거하는 것이다. 프로그램을 실행하면 Remove the nags to register This will make program fully registered :)) 메시지 창을 확인할 수 있다. OK 를 선택하여 메인 프로그램을 확인하고 프로그램을 종료하면 Oops! I am not registered!! 메시지 창을 출력한다. 이 두개의 메시지 창을 제거한 버전을 만들어보자. 먼저 첫 번째 메시지 창을 제거하기 위해서는 GetModuleHandleA 함수의 반환 값이 0이어야 한다. . text : 00401002 call GetModuleHandleA . text : 00401007 mov hInstance, eax . text : 0040100 C cmp eax, 0 . text : 0040100 F jz short loc_401024 그러나 0을 반환한다는 것은 모듈의 핸들을 얻지 못했다는 것이므로 프로그램이 정상 동작하지 않는다. 다시 말해 프로그램이 정상적으로 실행될 경우 반드시 출력되는 메시지 창이라고 이해할 수 있다. 여러 패치 방법이 있지만 여기서는 비교 조건을 변경하는 것으로 (jz -> jnz) 메시지 창 로직을 건너뛰자. . text : 0040100 F jnz short loc_401024 메인 프로그램 메시지 박스 호출(MessageBoxA) 후 종료 시 ExitProcess 함수 수행 전에 있는 메시지 창 생성 로직을 건너 뛰기 위해서 . text : 00401039 jmp short loc_40104D 로 수정하여 패치된 파일을 저장한다. 패치된 파일 실행 시 안내 메시지 창이 제거된 것

lena-tutorial-1

lena tutorial 1, 2 lena tutorial 은 리버스 엔지니어링을 연습하기 좋은 문제들로 구성되어 있어 많은 학습자들이 애용하는 자료이다. 튜토리얼을 실행하면 Evaluation period out of date. Purchase new license 메시지 창이 실행되는 것을 확인할 수 있다. 디버깅 도구를 이용하여 디스어셈블리를 확인해보면 “Keyfile.dat” 파일을 읽으려 한다는 것을 알 수 있다. CODE: 0040105 C push 0 ; hTemplateFile CODE: 0040105 E push offset unk_40216F ; dwFlagsAndAttributes CODE: 00401063 push 3 ; dwCreationDisposition CODE: 00401065 push 0 ; lpSecurityAttributes CODE: 00401067 push 3 ; dwShareMode CODE: 00401069 push 0 C0000000h ; dwDesiredAccess CODE: 0040106 E push offset FileName ; "Keyfile.dat" CODE: 00401073 call CreateFileA CODE: 00401078 cmp eax, 0 FFFFFFFFh CODE: 0040107 B jnz short loc_40109A CODE: 0040107 D