Apache의 ModSecurity가 설정된 경우
임의의 MIME-TYPE를 설정할 때 403 에러 응답을 하는 경우를 볼 수 있습니다.
이 경우 ModSecurity 설정 파일에 다음과 같이 내용을 추가합니다.
SecAction \
"id:900990,\
phase:1,\
nolog,\
pass,\
t:none,\
setvar:'tx.allowed_request_content_type=application/xxx|application/xxxx', \
setvar:tx.crs_setup_version=320"
구분자는 | 문자입니다.
타입을 추가한 뒤 아파치를 재시작하고 200 OK로 처리 됩니다.
2020년 3월 13일 금요일
2020년 3월 12일 목요일
아파치 mod_security2 설치 - 윈도우 환경
0. 적용환경
운영체제 : Windows 10 64bit
Apache 버전 : Apache2.4
mod_security 버전 : mod_security-2.9.3-win64-VS16
1. mod_security 설치
mod_security-2.9.3-win64-VS16.zip 파일 다운로드
다운로드 : https://www.apachelounge.com/download/
- yajl.dll 설치
apache24/bin 디렉토리에 yajl.dll 복사
- mod_security2.so 설치
apache24/modules 디렉토리에 mod_security2.so 복사
2. owasp-modsecurity-crs 설치
owasp-modsecurity-crs 다운로드
owasp-modsecurity-crs-3.2.0 버전으로 설치했습니다.
다운로드 : https://github.com/SpiderLabs/owasp-modsecurity-crs
- owasp-modsecurity-crs 설정
apache24/conf 디렉토리에 owasp-modsecurity-crs 디렉토리를 만들고
압축파일 내에 있는 crs-setup.conf.example파일과 rules 디렉토리를 복사합니다.
그리고 crs-setup.conf.example 파일 이름을 crs-setup.conf로 변경합니다.
3. crs-setup.conf 설정
crs-setup.conf 파일을 열어 최상단에 다음과 같이 수정합니다.
SecRuleEngine On
SecDefaultAction "deny,phase:2,status:403"
ServerTokens Full
ServerSignature Off
SecServerSignature "TestServer"
4. httpd.conf 설정
LoadModule unique_id_module modules/mod_unique_id.so
LoadModule security2_module modules/mod_security2.so
<IfModule security2_module>
Include conf/owasp-modsecurity-crs/crs-setup.conf
Include conf/owasp-modsecurity-crs/rules/*.conf
</IfModule>
5. 요청 응답 해더 확인
아파치를 재시작하고
응답 헤더에 Server가 TestServer 값으로 수정된 것을 확인합니다.
http://localhost
운영체제 : Windows 10 64bit
Apache 버전 : Apache2.4
mod_security 버전 : mod_security-2.9.3-win64-VS16
1. mod_security 설치
mod_security-2.9.3-win64-VS16.zip 파일 다운로드
다운로드 : https://www.apachelounge.com/download/
- yajl.dll 설치
apache24/bin 디렉토리에 yajl.dll 복사
- mod_security2.so 설치
apache24/modules 디렉토리에 mod_security2.so 복사
2. owasp-modsecurity-crs 설치
owasp-modsecurity-crs 다운로드
owasp-modsecurity-crs-3.2.0 버전으로 설치했습니다.
다운로드 : https://github.com/SpiderLabs/owasp-modsecurity-crs
- owasp-modsecurity-crs 설정
apache24/conf 디렉토리에 owasp-modsecurity-crs 디렉토리를 만들고
압축파일 내에 있는 crs-setup.conf.example파일과 rules 디렉토리를 복사합니다.
그리고 crs-setup.conf.example 파일 이름을 crs-setup.conf로 변경합니다.
3. crs-setup.conf 설정
crs-setup.conf 파일을 열어 최상단에 다음과 같이 수정합니다.
SecRuleEngine On
SecDefaultAction "deny,phase:2,status:403"
ServerTokens Full
ServerSignature Off
SecServerSignature "TestServer"
4. httpd.conf 설정
LoadModule unique_id_module modules/mod_unique_id.so
LoadModule security2_module modules/mod_security2.so
<IfModule security2_module>
Include conf/owasp-modsecurity-crs/crs-setup.conf
Include conf/owasp-modsecurity-crs/rules/*.conf
</IfModule>
5. 요청 응답 해더 확인
아파치를 재시작하고
응답 헤더에 Server가 TestServer 값으로 수정된 것을 확인합니다.
http://localhost
라벨:
아파치,
아파치헤더,
apache,
header server,
mod_security2,
windows
위치:
대한민국
2020년 3월 10일 화요일
우분투 - 아파치 톰캣 연동
apache2, tomcat9 연동예제입니다.
1. 설치
# apt-get install -y apache2
# service apache2 start
아파치2 접속확인
http://localhost
2. 톰캣설치
# apt-get install -y openjdk-8-jdk
자바가 필수로 설치된 환경에서 설치합니다.
/usr/share/tomcat9경로에 설치합니다.
# cd /usr/share
# wget http://apache.mirror.cdnetworks.com/tomcat/tomcat-9/v9.0.31/bin/apache-tomcat-9.0.31.tar.gz
# tar -zxvf apache-tomcat-9.0.31.tar.gz
# mv apache-tomcat-9.0.31 tomcat9
# rm apache-tomcat-9.0.31.tar.gz
톰캣 접속확인
http://localhost:8080
3. mod-jk 설치
# apt-get install libapache2-mod-jk
4. /etc/libapache2-mod-jk/workers.properties 수정
# which java
/usr/bin/java
# readlink /usr/bin/java
/etc/alternatives/java
# readlink /etc/alternatives/java
/usr/lib/jvm/java-8-openjdk-amd64/jre/bin/java
readlink /etc/alternatives/java에서 확인된 경로와 톰캣 설치 경로를 workers.properties 파일에 설정합니다.
# vi /etc/libapache2-mod-jk/workers.properties
workers.tomcat_home=/usr/share/tomcat9
workers.java_home=/usr/lib/jvm/java-8-openjdk-amd64
5. 톰캣 server.xml 파일 수정
# vi /usr/share/tomcat9/conf/server.xml
<Connector protocol="AJP/1.3"
port="8009"
address="0.0.0.0"
secretRequired="false"
redirectPort="8443" />
<Engine name="Catalina" defaultHost="localhost" jvmRoute="ajp13_worker">
Connector의 secretRequired, address 두 설정에 오류가 있으면 연동이 안될 수 있습니다.
worker 기본 설정값인 ajp13_worker를 jvmRoute에 입력합니다.
톰캣9 재시작
# sh /usr/share/tomcat9/bin/shutdown.sh
# sh /usr/share/tomcat9/bin/startup.sh
6. /etc/apache2/sites-enabled/000-default.conf 수정
# vi /etc/apache2/sites-enabled/000-default.conf
<VirtualHost *:80>
DocumentRoot /usr/share/tomcat9/webapps/ROOT
7. /etc/apache2/apache2.conf 수정
# vi /etc/apache2/apache2.conf
ServerName localhost
서버네임이 생략된경우 추가합니다.
8. 아파치2 재시작
# service apache2 restart
9. 접속확인
http://localhost
만약 접속이 안된다면 톰캣과 아차피 모두 재시작하고 확인합니다.
에러가 발생한다면 /var/log/apache2/ 경로에서 아파치 로그를 확인합니다.
1. 설치
# apt-get install -y apache2
# service apache2 start
아파치2 접속확인
http://localhost
2. 톰캣설치
# apt-get install -y openjdk-8-jdk
자바가 필수로 설치된 환경에서 설치합니다.
/usr/share/tomcat9경로에 설치합니다.
# cd /usr/share
# wget http://apache.mirror.cdnetworks.com/tomcat/tomcat-9/v9.0.31/bin/apache-tomcat-9.0.31.tar.gz
# tar -zxvf apache-tomcat-9.0.31.tar.gz
# mv apache-tomcat-9.0.31 tomcat9
# rm apache-tomcat-9.0.31.tar.gz
# sh /usr/share/tomcat9/bin/startup.sh
톰캣 접속확인
http://localhost:8080
3. mod-jk 설치
# apt-get install libapache2-mod-jk
4. /etc/libapache2-mod-jk/workers.properties 수정
# which java
/usr/bin/java
# readlink /usr/bin/java
/etc/alternatives/java
# readlink /etc/alternatives/java
/usr/lib/jvm/java-8-openjdk-amd64/jre/bin/java
readlink /etc/alternatives/java에서 확인된 경로와 톰캣 설치 경로를 workers.properties 파일에 설정합니다.
# vi /etc/libapache2-mod-jk/workers.properties
workers.tomcat_home=/usr/share/tomcat9
workers.java_home=/usr/lib/jvm/java-8-openjdk-amd64
5. 톰캣 server.xml 파일 수정
# vi /usr/share/tomcat9/conf/server.xml
<Connector protocol="AJP/1.3"
port="8009"
address="0.0.0.0"
secretRequired="false"
redirectPort="8443" />
<Engine name="Catalina" defaultHost="localhost" jvmRoute="ajp13_worker">
Connector의 secretRequired, address 두 설정에 오류가 있으면 연동이 안될 수 있습니다.
worker 기본 설정값인 ajp13_worker를 jvmRoute에 입력합니다.
톰캣9 재시작
# sh /usr/share/tomcat9/bin/shutdown.sh
# sh /usr/share/tomcat9/bin/startup.sh
6. /etc/apache2/sites-enabled/000-default.conf 수정
# vi /etc/apache2/sites-enabled/000-default.conf
<VirtualHost *:80>
ServerName localhost
JkMount /* ajp13_workerDocumentRoot /usr/share/tomcat9/webapps/ROOT
</VirtualHost>
# vi /etc/apache2/apache2.conf
ServerName localhost
서버네임이 생략된경우 추가합니다.
8. 아파치2 재시작
# service apache2 restart
9. 접속확인
http://localhost
만약 접속이 안된다면 톰캣과 아차피 모두 재시작하고 확인합니다.
에러가 발생한다면 /var/log/apache2/ 경로에서 아파치 로그를 확인합니다.
2016년 11월 19일 토요일
라즈베리파이 - 아파치 톰캣 연동
1. libapache2-mod-jk 설치
- 사전 준비사항
아파치, 톰캣 모두 설치가 된 상태에서 진행해야 합니다.
- 설치
root@raspberrypi:~# apt-get install libapache2-mod-jk
- 000-default.conf 설정
/etc/apache2/sites-enabled/000-default.conf 파일 <VirtualHost *:80> 다음 행에 다음 내용을 추가합니다.
root@raspberrypi:~# vi /etc/apache2/sites-enabled/000-default.conf
- workers.properties 파일 생성
root@raspberrypi:~# vi /etc/apache2/workers.properties
- 사전 준비사항
아파치, 톰캣 모두 설치가 된 상태에서 진행해야 합니다.
- 설치
root@raspberrypi:~# apt-get install libapache2-mod-jk
2. 아파치 설정
- apache2.conf 수정
/usr/lib/apache2/modules/mod_jk.so 파일이 있는지 확인 한 후
/etc/apache2/apache2.conf 파일 맨 아래 다음과 같이 수정합니다.
root@raspberrypi:~# vi /etc/apache2/apache2.conf
추가 내용
#JK_MODULE
LoadModule jk_module /usr/lib/apache2/modules/mod_jk.so
/etc/apache2/sites-enabled/000-default.conf 파일 <VirtualHost *:80> 다음 행에 다음 내용을 추가합니다.
root@raspberrypi:~# vi /etc/apache2/sites-enabled/000-default.conf
추가내용
JkMount /* loadbalancer- workers.properties 파일 생성
root@raspberrypi:~# vi /etc/apache2/workers.properties
추가내용
vi /etc/apache2/workers.properties
workers.java_home=/usr/lib/jvm/java-8-openjdk-armhf
worker.list=loadbalancer
worker.loadbalancer.type=lb
worker.loadbalancer.balanced_workers=instance1
worker.loadbalancer.sticky_session=1
worker.instance1.type=ajp13
worker.instance1.host=localhost
worker.instance1.port=8009
worker.instance1.lbfactor=1
- 톰캣 설정 확인
worker.loadbalancer.balanced_workers=instance1 라인 내용 중 instance1이 톰캣과 동일해야 합니다.
톰캣 설정 파일 server.xml을 수정합니다.
root@raspberrypi:~# vi /opt/tomcat/instance1/conf/server.xml
문서 중간 쯤
<Engine name="Catalina" defaultHost="localhost">
라인에 jvmRoute가 있는지 확인하고 수정합니다.
확인 및 수정
<Engine name="Catalina" defaultHost="localhost" jvmRoute="instance1">
- httpd-jk.conf 설정
root@raspberrypi:~# vi /etc/libapache2-mod-jk/httpd-jk.conf
JkWorkersFile /etc/libapache2-mod-jk/workers.properties 내용을 다음과 같이 수정합니다.
#JkWorkersFile /etc/libapache2-mod-jk/workers.properties
JkWorkersFile /etc/apache2/workers.properties
3. 서비스 재시작
- 톰캣 실행
root@raspberrypi:~# sh /opt/tomcat/instance1/bin/startup.sh
톰캣이 이미 실행중이라면
root@raspberrypi:~# sh /opt/tomcat/instance1/bin/shutdown.sh
root@raspberrypi:~# sh /opt/tomcat/instance1/bin/startup.sh
- 아파치 재실행
root@raspberrypi:~# service apache2 restart
- 접속 확인
80포트로 접속을 했을 때 톰캣으로 이동합니다.
2016년 11월 17일 목요일
라즈베리파이 - 아파치2와 톰캣 설치
1. 안내사항
2016-09-23 이미지 기준으로 작성했습니다.
라즈베리파이3 B+ 모델 기준입니다.
apt-get로 설치하는 패키지는 apache2, openjdk-8-jdk 입니다.
톰캣은 apache-tomcat-8.5.8을 수동으로 설치했습니다.
2. 아파치2 설치
- 설치
root@raspberrypi:~# apt-get install apache2
- 접속 확인
root@raspberrypi:~# ifconfig
IP 주소 확인 후 브라우저에서 확인 하시면 됩니다.
html 경로 : /var/www/html/index.html
3. 자바 설치
- 설치 확인
root@raspberrypi:~# java -version
openjdk version "1.8.0_40-internal"
OpenJDK Runtime Environment (build 1.8.0_40-internal-b04)
OpenJDK Zero VM (build 25.40-b08, interpreted mode)
- 설치(설치가 안된 경우 설치)
root@raspberrypi:~# apt-get install openjdk-8-jdk
4. 톰캣 설치
- 설치
아파치 톰캣 사이트 : http://tomcat.apache.org/
/opt 디렉토리에 tomcat 디렉토리를 생성 후 톰캣을 다운로드합니다.
다운로드한 압축파일은 압축을 풀고 디렉토리 이름을 instance1 로 수정합니다.
root@raspberrypi:/opt# mkdir tomcat
root@raspberrypi:/opt# cd tomcat/
root@raspberrypi:/opt/tomcat# wget http://mirror.apache-kr.org/tomcat/tomcat-8/v8.5.8/bin/apache-tomcat-8.5.8.tar.gz
root@raspberrypi:/opt/tomcat# tar -zxvf apache-tomcat-8.5.8.tar.gz
root@raspberrypi:/opt/tomcat# mv apache-tomcat-8.5.8 instance1
- 파일수정
root@raspberrypi:/opt/tomcat# which java
/usr/bin/java
root@raspberrypi:/opt/tomcat# readlink /usr/bin/java
/etc/alternatives/java
root@raspberrypi:/opt/tomcat# readlink /etc/alternatives/java
/usr/lib/jvm/java-8-openjdk-armhf/jre/bin/java
readlink로 경로를 확인한 후 startup.sh, shutdown.sh 파일을 수정합니다.
root@raspberrypi:/opt/tomcat# cd instance1/bin/
root@raspberrypi:/opt/tomcat/instance1/bin# vi startup.sh
root@raspberrypi:/opt/tomcat/instance1/bin# vi shutdown.sh
#!/bin/sh에 아래 내용 추가
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-armhf
export CATALINA_HOME=/opt/tomcat/instance1
export CATALINA_BASE=/opt/tomcat/instance1
- 실행 확인
실행
root@raspberrypi:/opt/tomcat/instance1/bin# sh startup.sh
종료
root@raspberrypi:/opt/tomcat/instance1/bin# sh shutdown.sh
root@raspberrypi:~# ifconfig
IP 주소 확인 후 브라우저에서 포트번호 8080을 추가해서 확인 하시면 됩니다.
마치며..
아파치와 톰캣을 연동하려면 mod-jk를 사용해야 합니다.
피드 구독하기:
글 (Atom)