IBM HTTPServer - HTTP 메소드 차단
WebServer 메소드 차단 방법
- Test OS : CentOS 7.2
- Test Version : IBM HTTPServer v8.5
IBM HTTPServer 에서 보안상의 이유로 HTTP 메소드 차단 요청이 들어와 테스트한 내용 정리.
- IHS의 경우 apache 기반이기 때문에 해당 설정은 apache에서도 같이 적용이 가능.
httpd.conf 파일 수정
#GET, POST를 제외한 메소드 제한
<Directory />
Options FollowSymLinks
AllowOverride None
<LimitExcept GET POST>
Order allow,deny
Deny from all
</LimitExcept>
</Directory>
보통 디렉토리 속성안에 넣어서 사용하지만 디렉토리 속성을 안사용할경우 로케이션을 사용.
<Location "/*">
<LimitExcept GET POST>
Order allow,deny
Deny from all
</LimitExcept>
</Location>
다른 방안으로 rewrite 사용하는 방법도 있다.
LoadModule rewrite_module modules/mod_rewrite.so
<IfModule mod_rewrite.c>
RewriteEngine On
# GET, POST를 제외하고 모두 405 페이지로 이동
RewriteCond %{REQUEST_METHOD} !^(GET|POST)
RewriteRule .* - [R=405,L]
</IfModule>
메소드 차단 테스트로는 해당 메소드 파일을 만들어서 요청하는 방법도 있지만, 간단하게 telnet으로 테스트 가능.
$telnet {domain_address} 80
OPTIONS http://{domain_address}/ HTTP/1.0
OPTIONS http://google.com/ HTTP/1.0
Enter Enter
#모든 메소드 허용의 경우
HTTP/1.1 200 OK
Date: Wed, 04 Jul 2018 01:44:40 GMT
Allow: GET,HEAD,POST,OPTIONS
Content-Length: 0
Connection: close
Content-Type: text/html
#메소드가 차단된 경우
HTTP/1.0 405 Method Not Allowed
Allow: GET, HEAD
#
HTTP/1.1 403 Forbidden
Allow: GET, HEAD
위와 같은 방법으로 안대는 경우
web.xml에 secutity-constraint 속성으로 해당 메소드 제한
#web.xml 아래와 같이 메소드 제한 설정
<security-constraint>
<web-resource-collection>
<web-resource-name></web-resource-name>
<url-pattern>/*</url-pattern>
<http-method>HEAD</http-method>
<http-method>DELETE</http-method>
<http-method>PUT</http-method>
<http-method>OPTIONS</http-method>
</web-resource-collection>
</security-constraint>
0 Comments:
댓글 쓰기