기본 콘텐츠로 건너뛰기

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

  1. urlscan_setup 실행. 설치.
  2. \windows\system32\inetsrv\urlscan\urlscan.ini 파일을 열어 다음 수정(RemoveServerHeader=0 을 RemoveServerHeader=1 로 변경)
  3. 서비스에서 IIS Admin Service 재시작.

IIS 7.0

  1. IIS 관리자를 열고 관리하려는 수준으로 이동합니다.
  2. 기능 보기에서 HTTP 응답 헤더를 두 번 클릭합니다.
  3. HTTP 응답 헤더 페이지에서 제거할 헤더를 선택합니다.
  4. 작업 창에서 제거를 클릭하고 예를 클릭합니다.

2) 참고 URL

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

1) 조치 방법

“/etc/nginx/sites-available/default” 파일 혹은 “nginx.conf” 파일에서 server_tokens off; 설정

2) 참고 URL

http://opens.kr/44

5. NodeJS

1) 조치 방법

NodeJS의 경우 별도로 Response Message에 버전을 포함하지 않으면 버전 정보가 전달되지 않는다. (res.setHeader, res.writeHead)

2) 참고 URL

http://pyrasis.com/nodejs/nodejs-HOWTO

6. Resin

1) 조치 방법

“resin.xml” 파일을 열어서 태그 밑에 Foo/1.0 을 입력한다.

ex.

<cluster id="app-tier">
...
<server-header>Foo/1.0</server-header>
...
<host id="">
...
</host>
</cluster>
</resin>
2) 참고 URL

http://changpd.blogspot.kr/2013/10/blog-post_14.html

7. Tomcat

1) 조치 방법

응답 헤더의 버전 정보 제거

“server.xml” 파일을 열어서 Connector 태그에 protocol과 server 속성을 추가하여 헤더 값에 포함될 서버 정보를 지정할 수 있다.
ex.

에러 페이지 내 버전 정보 제거

“org/apache/catalina/util/ServerInfo.properties” 파일을 열어서 server.info=Apache Tomcat Version 7.0.35 → server.info=Apache Tomcat Version X
(버전 확인이 필요할 시 사용 스크립트 파일 : $CATALINA_HOME/bin/version.sh)

2) 참고 URL

이 블로그의 인기 게시물

데일 카네기 인간관계론 정리

American Fuzzy Lop And Address Sanitizer

American Fuzzy Lop And Address Sanitizer Address Sanitizer(ASAN) 단지 gcc/clang에 -fsanitize=address 옵션을 추가하는 것으로 간단히 사용할 수 있지만 그 효과는 충분하다. Example Out Of Bounds Read #include <stdio.h> int main() { int a[ 2 ] = { 3 , 1 }; int i = 2 ; printf ( "%i\n" , a[i]); } 예제 파일을 OutOfBoundsRead.c 로 생성하고 ASAN 옵션을 지정하여 clang 으로 컴파일하자. clang -g -fsanitize = address -fno -omit -frame -pointer OutOfBoundsRead . c -o OutOfBoundsRead 생성된 OutBoundsRead 파일을 실행하면 다음과 같은 결과를 볼 수 있다. ================================================================= ==3678==ERROR: AddressSanitizer: stack-buffer-overflow on address 0x7ffc0ba87428 at pc 0x47b7db bp 0x7ffc0ba87390 sp 0x7ffc0ba87388 READ of size 4 at 0x7ffc0ba87428 thread T0 ==3678==WARNING: Trying to symbolize code, but external symbolizer is not initialized! #0 0x47b7da (/root/ASAN/OutOfBoundsRead+0x47b7da) #1 0x7faba0260f44 (/lib/x86_64-linux-gnu/libc.so.6+0x21f44) #2 0x...