Install Web Application Firewall (WAF) with NGINX Debian 10
1) ติดตั้ง Nginx stable เวอร์ชั่นล่าสุด ถ้าลงโดยใช้ repo ที่มีอยุ่แล้วจะติดตั้งไม่ได้ ต้องลงด้วยตัวเองตามลิงค์ด้านล่าง ต้องใช้เวอร์ชั้น 1.11.5 ขึ้นไปเท่านั้น
data:image/s3,"s3://crabby-images/b98ef/b98eff360fc6e3348a4008d86557b8cafacf6248" alt=""
ติดตั้ง Packages ที่จำเป็นต้องใช้ ตามด้านล่าง
apt-get install -y apt-utils autoconf automake build-essential git libcurl4-openssl-dev libgeoip-dev liblmdb-dev libpcre++-dev libtool libxml2-dev libyajl-dev pkgconf wget zlib1g-dev
2) clone ModSecurity v3 จากเว็บ github และทำการติดตั้ง
git clone --depth 1 -b v3/master --single-branch https://github.com/SpiderLabs/ModSecurity
cd ModSecurity
git submodule init
git submodule update
./build.sh
./configure
data:image/s3,"s3://crabby-images/bf021/bf021fc2eb83adf2600fdf0d84997126264051bd" alt=""
data:image/s3,"s3://crabby-images/3371d/3371dff2cf579b745063892905cf8feaf8225cd0" alt=""
data:image/s3,"s3://crabby-images/19e0a/19e0acd376c0f78b5a9e80e5c3394f9d744c8d34" alt=""
data:image/s3,"s3://crabby-images/3c2ba/3c2ba3412cda4474a93d5aea61357541854d2477" alt=""
data:image/s3,"s3://crabby-images/e7a72/e7a727a69e5333d2142279dd9dc6669a9962d425" alt=""
make
data:image/s3,"s3://crabby-images/2c32b/2c32b98978d5d87161db193421ce21526c801489" alt=""
make install
cd ..
data:image/s3,"s3://crabby-images/a1d02/a1d023623bfa02fe3ace266384931544ba0b4c05" alt=""
data:image/s3,"s3://crabby-images/1eb5d/1eb5d0e15d976167c89d3a0f55fb7e3bd179d6f1" alt=""
3) เช็คเวอร์ชั่น Nginx ที่ติดตั้งอยู่
data:image/s3,"s3://crabby-images/df5ec/df5ec5d81cfe204ede8836efdee6811a8b00c23c" alt=""
4) ติดตั้งตัว ModSecurity connector สำหรับ nginx
git clone --depth 1 https://github.com/SpiderLabs/ModSecurity-nginx.git
data:image/s3,"s3://crabby-images/d3eec/d3eeceff185cc60161cfa6768ade02d0140fe42e" alt=""
เช็คเวอร์ชั่น nginx ที่ติดตั้งแล้วโหลด sourcecode ให้ตรงกับเวอร์ชั่นที่เราติดตั้ง
wget http://nginx.org/download/nginx-1.xx.xx.tar.gz
data:image/s3,"s3://crabby-images/dc580/dc580198f150288a717149ff3e2715a04c58df2d" alt=""
จากนั้นแตกไฟล์ที่โหลดมา
tar -xvzmf nginx-1.xx.xx.tar.gz
data:image/s3,"s3://crabby-images/dfde5/dfde516d4ef89fe4c1728fd3ce15f49d15cf180b" alt=""
cd เข้าไปในไฟล์ที่แตกมาแล้วรันทำสั่งต่อไปนี้
./configure --with-compat --add-dynamic-module=../ModSecurity-nginx
data:image/s3,"s3://crabby-images/5c962/5c9629df7dc61dde3d755ecb8389c489a6db3d9b" alt=""
data:image/s3,"s3://crabby-images/d6769/d6769f38f16b071873282d16f4b6379e673db241" alt=""
make modules
data:image/s3,"s3://crabby-images/71889/7188984b4bb8328d751dc7602a00e9184ea38aed" alt=""
cp objs/ngx_http_modsecurity_module.so /etc/nginx/modules
cd ..
data:image/s3,"s3://crabby-images/2bb4a/2bb4ad3af140d3e9f4afc059b0217450b5f93ce0" alt=""
5) ทำการเพิ่มคอนฟิกใน nginx.conf
vim /etc/nginx/nginx.conf
เพิ่มคำสั่งนี้ลงในไฟล์
load_module modules/ngx_http_modsecurity_module.so;
data:image/s3,"s3://crabby-images/97e52/97e525527716506fbdcee7f19c6ed840b87fad91" alt=""
6) ขั้นตอนสุดท้าย ทำการคอนฟิก สั่งรัน และ ทดสอบ ModSecurity
mkdir /etc/nginx/modsec
wget -P /etc/nginx/modsec/ https://raw.githubusercontent.com/SpiderLabs/ModSecurity/v3/master/modsecurity.conf-recommended
mv /etc/nginx/modsec/modsecurity.conf-recommended /etc/nginx/modsec/modsecurity.conf
data:image/s3,"s3://crabby-images/f3695/f369588e5eb52e3b50eaff4974dbd937ca08bf22" alt=""
วิธีสร้าง rule โดย สามารถใส่ไฟล์ rule ที่ path /etc/nginx/modsec
ตัวอย่าง
data:image/s3,"s3://crabby-images/fc3fe/fc3fed2c375d93dfa35a4bf205298d88b87c5a17" alt=""
# From https://github.com/SpiderLabs/ModSecurity/blob/master/
# modsecurity.conf-recommended
#
# Edit to set SecRuleEngine On
Include "/etc/nginx/modsec/modsecurity.conf"
# Basic test rule
SecRule ARGS:testparam "@contains test" "id:1234,deny,status:403"
เพิ่ม rule ลงในไฟล์ nginx.conf เพื่อทำการทดสอบ
modsecurity on;
modsecurity_rules_file /etc/nginx/modsec/main.conf;
data:image/s3,"s3://crabby-images/b6242/b62420b795a6d16ce885fcd6d75f72d733f4be72" alt=""
$ curl localhost?testparam=test
data:image/s3,"s3://crabby-images/20b9d/20b9d6822519c9b507333988471397d528f1b5f9" alt=""
REF.
data:image/s3,"s3://crabby-images/8c71e/8c71eccc733d3e6b47a3156e139b532f3b72986a" alt=""