“Web applications – yours, mine, everyone’s – are terribly insecure on average. We struggle to keep up with the security issues and need any help we can get to secure them.” – Ivan Ristić, creator of ModSecurity
Today I wanna show you how to install Modsecurity on CentOS 7 and then how to configure it on NGINX .
1.First we should Install dependency and required packages:
# yum install -y autoconf automake build-essential git libcurl4-openssl-dev libgeoip-dev liblmdb-dev libpcre++-dev libtool libxml2-dev libyajl-dev pkgconf wget zlib1g-dev
2.then we should update repository to install NGINX
# yum install https://extras.getpagespeed.com/release-el7-latest.rpm -y
data:image/s3,"s3://crabby-images/b0366/b0366d4d36e3961d1bb224627209bf3a783f9027" alt=""
3.Now we start to install NGINX
# yum install nginx
# service nginx start
data:image/s3,"s3://crabby-images/4f4dc/4f4dc78cf69ccf02d6dcb86f3dcd934fa61fceb4" alt=""
4. In this step we start to install ModSecurity
# yum install nginx-module-security
data:image/s3,"s3://crabby-images/8539c/8539cc5743e980cc9afb60b375ac8310d0698d7c" alt=""
data:image/s3,"s3://crabby-images/06191/061916426083f34154af1e9cef0991589cd17582" alt=""
data:image/s3,"s3://crabby-images/aef38/aef38389a54e8b6eb805fbf077ecbec92e1b30df" alt=""
5.Add the plugin to the nginx configuration file located in /etc/nginx/nginx.conf
load_module modules/ngx_http_modsecurity_module.so;
data:image/s3,"s3://crabby-images/07b92/07b92ea1332182e5a095246a155a4a61e35f1445" alt=""
6. Create a file in /etc/nginx/modsec/main.conf and add following text
This is a simple test for droping a request
# From https://github.com/SpiderLabs/ModSecurity/blob/master/
# modsecurity.conf-recommended
#
# Edit to set SecRuleEngine On
Include "/etc/nginx/modsecurity.conf"
# Basic test rule
SecRule ARGS:testparam "@contains test" "id:1234,deny,status:403"
data:image/s3,"s3://crabby-images/22523/225237285adf887290f1d22ec69fc41cc0037339" alt=""
7. Add following configuration into website configuration file located in /etc/nginx/conf.d/ and in server section
server {
# ...
modsecurity on;
modsecurity_rules_file /etc/nginx/modsec/main.conf;
}
data:image/s3,"s3://crabby-images/7c70f/7c70fccb7f3d232ecf9cad75a40812f90658358e" alt=""
8.Now you can restart NGINX and test ModSecurity with a simple injection query
# service nginx restart
# curl localhost?testparam=test
data:image/s3,"s3://crabby-images/97ed0/97ed0abef50ab29437a138b7b0e614615f7027d1" alt=""
data:image/s3,"s3://crabby-images/d7e80/d7e80de8c02e98b3b9748ed9d9a954760b3e9ff6" alt=""