ModSecurity原本是Apache上的一款开源WAF模块,可以有效的增强Web安全性。目前已经支持Nginx和IIS,配合Nginx的灵活和高效可以打造成生产级的WAF,是保护和审核Web安全的利器。
' }) s- X! g$ |# V: p0 `( v2 s1 `. p+ k5 v9 D* ^
1 R, ^# b& q. U0 c& r在这篇文章中,我们将学习配置ModSecurity与OWASP的核心规则集。/ j/ P$ I; [$ F/ }5 ^
! F9 E) A- y1 l
( ^- P, x* Q- g( I( Z5 a+ ^+ R什么是ModSecurity
2 k' n* s- `% \$ p) MModSecurity是一个入侵侦测与防护引擎,它主要是用于Web应用程序,所以也被称为Web应用程序防火墙(WAF)。它可以作为Web服务器的模块或是单独的应用程序来运作。ModSecurity的功能是增强Web Application 的安全性和保护Web application以避免遭受来自已知与未知的攻击。
- w7 C# O! o+ A
8 n# C) X( N f% [. v5 [. j
' \7 i) f( Q: n# wModSecurity计划是从2002年开始,后来由Breach Security Inc.收购,但Breach Security Inc.允诺ModSecurity仍旧为Open Source,并开放源代码给大家使用。最新版的ModSecurity开始支持核心规则集(Core Rule Set),CRS可用于定义旨在保护Web应用免受0day及其它安全攻击的规则。
; O. A+ s+ K9 A0 ~0 P! B& z1 D U+ f# ?+ w( m" w6 q; m
# ]- M: ?2 e" n4 d4 a3 a
ModSecurity还包含了其他一些特性,如并行文本匹配、Geo IP解析和信用卡号检测等,同时还支持内容注入、自动化的规则更新和脚本等内容。此外,它还提供了一个面向Lua语言的新的API,为开发者提供一个脚本平台以实现用于保护Web应用的复杂逻辑。
7 s! `9 O/ F+ n$ k
' B0 Y( y& D+ z% T% T3 j6 t/ i! Z% X- J9 O, k$ `: _; A! ^" P
官网: https://www.modsecurity.org/
, j6 H4 O' N5 e1 h5 A2 O7 m2 u, W- |2 h
3 a" }' t5 H8 J! X% A T( \/ X7 |什么是OWASP CRS
: B0 |: n2 d* H/ gOWASP是一个安全社区,开发和维护着一套免费的应用程序保护规则,这就是所谓OWASP的ModSecurity的核心规则集(即CRS)。ModSecurity之所以强大就在于OWASP提供的规则,我们可以根据自己的需求选择不同的规则,也可以通过ModSecurity手工创建安全过滤器、定义攻击并实现主动的安全输入验证。% ~3 Q; [9 E Q
$ `, N k7 b9 {8 W5 `! J. i. M9 M) X' L5 R' l
ModSecurity核心规则集(CRS)提供以下类别的保护来防止攻击。
" j8 v$ |& v( R2 O( Q8 Z" E1 T7 _' Q
: d6 x- x6 U; J/ }0 KHTTP Protection(HTTP防御)7 y' v! H: Q2 I1 D
HTTP协议和本地定义使用的detectsviolations策略。, i @8 l& }! `: l/ F
- G& r" G* h' W& U$ y1 m
) x3 |8 O- J1 A- `7 j
Real-time Blacklist Lookups(实时黑名单查询)+ i S0 ^1 o- ~9 }- q' T
利用第三方IP名单。$ S1 R4 q. c5 O, s2 o9 l
# }9 ]7 Z7 ?' J; ]( [
: n. R* K8 b6 S4 x3 j! aHTTP Denial of Service Protections(HTTP的拒绝服务保护)2 D% _* r1 F' D' A
防御HTTP的洪水攻击和HTTP Dos攻击。
5 M5 W6 W( I8 z- _( d& E( @6 C0 B; g" \
5 H% D* `/ z* ]# r
Common Web Attacks Protection(常见的Web攻击防护)9 Q4 g6 D; @3 p
检测常见的Web应用程序的安全攻击。
; _8 ~! q- {0 O5 ~
" V0 {# V0 u0 K8 `- n& g+ B1 o t- ?0 U J
Automation Detection(自动化检测)4 n1 R" H' j/ ? [- y5 A# L \, ]
检测机器人,爬虫,扫描仪和其他表面恶意活动。/ I2 w8 k) p9 d. U8 }# _+ w: Z
. g( T8 E+ [3 \5 A% l5 e" l0 P
j% V# S. x1 ~Integration with AV Scanning for File Uploads(文件上传防病毒扫描)
+ N# I/ E5 w5 H6 H; Q0 ]7 Y1 j检测通过Web应用程序上传的恶意文件。
. c8 c1 d) ?- y1 K) ^8 D% q" V9 ~4 z
1 ~& _0 z: T# Z5 D3 M7 G% Y; RTracking Sensitive Data(跟踪敏感数据)
1 Q; [# ]$ L9 O- ~$ V1 w+ p% e. z+ X信用卡通道的使用,并阻止泄漏。 d; o* Y# `; _, ^7 ^% b
0 t; F7 H" P) f
! B2 \) s7 }1 v |
Trojan Protection(木马防护). G. z- F) r) p. U( e J6 x, T; Y
检测访问木马。3 a7 {; U. U6 ~9 R4 m
$ P+ n" E1 _* Y9 s
; r5 }# H3 f. m- ^6 B
Identification of Application Defects(应用程序缺陷的鉴定)$ C8 b2 Z2 H" N8 Q S/ P5 }7 B( ~2 ~
检测应用程序的错误配置警报。3 r3 S5 v8 X" v/ ]/ M1 s
; f6 t) _3 n2 @2 `: j8 S% { V& @1 B1 `* N
Error Detection and Hiding(错误检测和隐藏)
( u& [0 h1 Q5 O: x M, y, k _检测伪装服务器发送错误消息。( G8 T5 K! u( d- B* T( {
: g# h9 H3 m# f4 ^
# ?* [6 K, D) F. n: x' b# Z安装ModSecurity5 X- ]$ ^1 F# G% r3 I' b* m
软件基础环境准备
( F }1 `- ^( @2 b: A+ {下载对应软件包/ V2 d6 o; C% S
$ cd /root
4 k; N S9 r+ V; J$ wget 'http://nginx.org/download/nginx-1.9.2.tar.gz'" z! o( x: B! c% C& K0 z9 ?
$ wget -O modsecurity-2.9.1.tar.gz https://github.com/SpiderLabs/ModSecurity/releases/download/v2.9.1/modsecurity-2.9.1.tar.gz8 a0 R" y7 ]* a. h8 ^0 j* {
安装Nginx和ModSecurity依赖包3 a; \9 u$ o5 a. O- @+ e% N1 l
Centos/RHEL
8 q7 e& C1 a8 ]' j% ^! P, z2 f& l K: j3 y1 G0 m
9 J3 I* f0 N. [3 f
$ yum install httpd-devel apr apr-util-devel apr-devel pcre pcre-devel libxml2 libxml2-devel zlib zlib-devel openssl openssl-devel0 P8 d- V( o9 F! z% }2 p* ^
Ubuntu/Debian
9 I6 k+ y |# T+ z
) z4 U) M2 G4 {. z) ] ~# e5 \% q
8 _- B z2 A1 U/ B) Z$ apt-get install libreadline-dev libncurses5-dev libssl-dev perl make build-essential git libpcre3 libpcre3-dev libtool autoconf apache2-dev libxml2 libxml2-dev libcurl4-openssl-dev g++ flex bison curl doxygen libyajl-dev libgeoip-dev dh-autoreconf libpcre++-dev4 x) a7 e8 j' ?5 B R' w3 B
编译安装ModSecurity
. d' U& p3 [+ V* f! v- E+ l* g. INginx加载ModSecurity模块有两种方式:一种是编译为Nginx静态模块,一种是通过ModSecurity-Nginx Connector加载动态模块。
! l; C6 D7 l. z; p1 k G6 f+ W; i! x! t, K8 \" { Y; \
( H- j, E$ F9 _5 [
方法一:编译为Nginx静态模块5 Q+ w* @+ d' ` R, X
2 m5 @$ l- y+ h
4 n7 y; S( u3 i5 x3 p6 z8 V
编译为独立模块(modsecurity-2.9.1)( P8 A3 O! I: [2 h2 S# K
$ tar xzvf modsecurity-2.9.1.tar.gz: L" B5 R3 M$ Y2 C' ~
$ cd modsecurity-2.9.1/
& l( c% V3 p. H# q1 l B [$ ./autogen.sh& m* R+ ~9 j2 z. a) H/ k
$ ./configure --enable-standalone-module --disable-mlogc% N- [( X8 I" Z7 B% E: I2 F
$ make5 R3 d& X8 Q m! p7 f! x- }
编译安装Nginx并添加ModSecurity模块
9 J, E; g) I& u! x7 f7 b, J# r$ tar xzvf nginx-1.9.2.tar.gz
# L6 i+ _6 w0 h5 y5 o6 ]$ cd nginx-1.9.26 g% n' }5 ^1 O+ m0 L
$ ./configure --add-module=/root/modsecurity-2.9.1/nginx/modsecurity/
6 E8 c# `; w1 Q8 ?/ S! Z1 u2 V$ make && make install L" R& x, |3 ~# v6 k
方法二:编译通过ModSecurity-Nginx Connector加载的动态模块
: T0 f" ?9 j/ m! I& D$ I
& @! h- P* |0 r( v W7 f4 c$ d/ o+ `) C$ Z3 D
编译LibModSecurity(modsecurity-3.0)7 X( G. {- ?' {1 u
$ cd /root
2 ~: A* t7 N F" `7 a$ git clone https://github.com/SpiderLabs/ModSecurity0 K: C9 J$ n4 h# y; d
$ cd ModSecurity9 a! F* n' l0 w4 e% m; \9 t( _
$ git checkout -b v3/master origin/v3/master: g5 k! H/ g" e! u( Y e
$ sh build.sh
9 n4 j0 T% |. B$ git submodule init! s& O9 V: f) a
$ git submodule update
_. |9 v8 @8 x; r$ ./configure2 E2 T7 \" L9 ] s$ V
$ make) b; c3 f) U5 o8 T* L
$ make install0 S( h) d# r$ t! \; @ I4 b
LibModSecurity会安装在 /usr/local/modsecurity/lib 目录下。# W3 }' o; ]+ Q E2 d+ A H
* l2 J3 m# O9 G4 l' G2 w4 X |' X& E
$ ls /usr/local/modsecurity/lib
% a B# c7 s7 ulibmodsecurity.a libmodsecurity.la libmodsecurity.so libmodsecurity.so.3 libmodsecurity.so.3.0.0
/ |; z, a8 k, F编译安装Nginx并添加ModSecurity-Nginx Connector模块
5 o I8 Q" g! f+ C4 R- A8 S) w使用ModSecurity-Nginx模块来连接LibModSecurity
, B. M' B" g* H* @/ s, P' }: b5 i* _5 `+ m f8 B7 s2 k; P) V3 h& _
% u0 w5 d) |$ G( t, N" K$ cd /root. l. ]# \+ z3 D
$ git clone https://github.com/SpiderLabs/ModSecurity-nginx.git modsecurity-nginx7 r9 \3 X+ w( x0 U/ e, G
$ tar xzvf nginx-1.9.2.tar.gz
8 Z6 h& N( `" o8 z2 J- L; B$ cd nginx-1.9.2
. A3 v. ?4 J* ^3 s$ ./configure --add-module=/root/modsecurity-nginx
4 b9 M' y. ` w( j( F$ make
* ]: I: u' B# `) |2 j$ make && make install/ D! [& c9 E+ l( u3 m
添加OWASP规则
- H3 L! }3 S3 N; a1 |ModSecurity倾向于过滤和阻止Web危险,之所以强大就在于规则。OWASP提供的规则是社区志愿者维护的被称为核心规则CRS,规则可靠强大,当然也可以自定义规则来满足各种需求。5 \& L5 A3 I1 x/ @% e. L
9 H) q& s. t. q
4 x% Z# ?2 r6 c; U {6 u1 k5 g9 b下载OWASP规则并生成配置文件
7 A6 X' L' \) n3 u' W$ git clone https://github.com/SpiderLabs/owasp-modsecurity-crs.git
4 \% e7 b* F7 ]* k" X9 F$ cp -rf owasp-modsecurity-crs /usr/local/nginx/conf/% ^* {/ Z9 W! _! N
$ cd /usr/local/nginx/conf/owasp-modsecurity-crs/ y; J5 `4 [& U+ o J& {' L6 J$ ?# U( I$ i
$ cp crs-setup.conf.example crs-setup.conf# w) x4 j' |. J
配置OWASP规则
- I* U: w" c+ u/ z" Q' [编辑crs-setup.conf文件7 L/ @0 t$ k% N; |% L
* { A) d1 F" i2 u9 i; Y2 D* e6 O& k7 V( b. Q
$ sed -ie 's/SecDefaultAction "phase:1,log,auditlog,pass"/#SecDefaultAction "phase:1,log,auditlog,pass"/g' crs-setup.conf
0 d! |; K7 e8 F# o: c$ sed -ie 's/SecDefaultAction "phase:2,log,auditlog,pass"/#SecDefaultAction "phase:2,log,auditlog,pass"/g' crs-setup.conf
: B3 b8 r. y. W$ sed -ie 's/#.*SecDefaultAction "phase:1,log,auditlog,deny,status:403"/SecDefaultAction "phase:1,log,auditlog,deny,status:403"/g' crs-setup.conf$ _& B9 [$ P5 N% Q9 T2 @
$ sed -ie 's/# SecDefaultAction "phase:2,log,auditlog,deny,status:403"/SecDefaultAction "phase:2,log,auditlog,deny,status:403"/g' crs-setup.conf
4 f8 c5 F# f4 p' [默认ModSecurity不会阻挡恶意连接,只会记录在Log里。修改SecDefaultAction选项,默认开启阻挡。
3 Y. t. q: z9 C! a
% H7 R9 H4 p& X' l" r
H0 n L7 f7 K0 C启用ModSecurity模块和CRS规则9 T5 Z; F4 A! x9 s
复制ModSecurity源码目录下的modsecurity.conf-recommended和unicode.mapping到Nginx的conf目录下,并将modsecurity.conf-recommended重新命名为modsecurity.conf。1 @% Y: U$ S% O* t- F! P7 B- u# D
+ E$ ^) E' @" a |* _2 e1 R3 Q( K9 i* G5 i9 N
modsecurity.conf-recommended是ModSecurity工作的主配置文件。默认情况下,它带有.recommended扩展名。要初始化ModSecurity,我们就要重命名此文件。. m! v: N+ H1 T6 o( B/ \, [; i
/ e, y, s0 `$ R h% V: ~, @( i: ~, V
7 ]7 ], X3 o/ l" a: ?+ |! Z$ cd /root/modsecurity-2.9.1/
; Z# m# B d3 P$ cp modsecurity.conf-recommended /usr/local/nginx/conf/modsecurity.conf 6 y/ A( r: O4 R( m7 ?
$ cp unicode.mapping /usr/local/nginx/conf/
, k z- F& H' }将SecRuleEngine设置为On,默认值为DetectOnly即为观察模式,建议大家在安装时先默认使用这个模式,规则测试完成后在设置为On,避免出现对网站、服务器某些不可知的影响。7 u( m7 e0 X4 J4 r
, a- }) Y) K) ~1 a9 M) s
8 n# M* g% y! V
$ vim /usr/local/nginx/conf/modsecurity.conf
( X1 v5 F% e0 M& E. _# eSecRuleEngine On y" N; ]' f E' `- t+ p
ModSecurity中几个常用配置说明:* R$ p X# V: t$ w4 G( D* O) Z. P" c
" D5 V1 d0 A/ K8 o0 Y6 z
. R) k4 P# }4 `: ~
1.SecRuleEngine:是否接受来自ModSecurity-CRS目录下的所有规则的安全规则引擎。因此,我们可以根据需求设置不同的规则。要设置不同的规则有以下几种。SecRuleEngine On:将在服务器上激活ModSecurity防火墙,它会检测并阻止该服务器上的任何恶意攻击。SecRuleEngine Detection Only:如果设置这个规则它只会检测到所有的攻击,并根据攻击产生错误,但它不会在服务器上阻止任何东西。SecRuleEngine Off:这将在服务器上上停用ModSecurity的防火墙。
9 q8 H1 S5 o* Q3 s5 G" J) a
7 q+ l6 Y* c5 j2 ]$ ?2 I; C1 s% t' R- ~% A- I6 p
2.SecRequestBodyAccess:它会告诉ModSecurity是否会检查请求,它起着非常重要的作用。它只有两个参数ON或OFF。
6 y) k7 d2 l2 o/ d9 ^1 q. V2 B% |8 A: B% Q! w" S5 S
8 N* _# B& |( {7 I
3.SecResponseBodyAccess:如果此参数设置为ON,然后ModeSecurity可以分析服务器响应,并做适当处理。它也有只有两个参数ON和Off,我们可以根据求要进行设置。
4 r/ a- M- r6 R! [# |6 i6 }* \# X w$ L
/ m; P6 o+ @3 K7 `# v# {4.SecDataDir:定义ModSecurity的工作目录,该目录将作为ModSecurity的临时目录使用。7 |4 M1 D9 h6 V4 X; v; F( G6 x
4 H) `6 s+ R e
o, Z' o7 |, g$ ?
在 owasp-modsecurity-crs/rules 下有很多定义好的规则,将需要启用的规则用Include指令添加进来就可以了。
+ B! ^5 G6 z0 A1 f% \6 a+ v
" D$ l/ n9 R4 c7 J# N, z
- {6 {' i4 i. M+ k3.x版本CRS+ p4 n, W% \1 g- ]
$ cd /usr/local/nginx/conf/owasp-modsecurity-crs4 ]3 L2 K1 A! G7 z9 _
# 生成例外排除请求的配置文件' P: Y( w7 }% X) G6 L8 X
$ cp rules/REQUEST-900-EXCLUSION-RULES-BEFORE-CRS.conf.example rules/REQUEST-900-EXCLUSION-RULES-BEFORE-CRS.conf- _9 B" P% X, c. }; K% n9 I9 }
$ cp rules/RESPONSE-999-EXCLUSION-RULES-AFTER-CRS.conf.example rules/RESPONSE-999-EXCLUSION-RULES-AFTER-CRS.conf
! [* j: k. _. I% q& y+ v$ cp rules/*.data /usr/local/nginx/conf3 k6 {- O/ j `0 ^# {9 L
为了保持modsecurity.conf简洁,这里新建一个modsec_includes.conf文件,内容为需要启用的规则。- f o* L( w0 N) y3 F; k
0 j6 X8 f9 f3 i" N3 @) V8 |( b9 x
: a# A+ s0 Z! _# |$ vim /usr/local/nginx/conf/modsec_includes.conf
) b" U( \4 t# \/ ^+ Q3 W! J9 h7 q2 E$ S! P' r6 @8 B# S3 X
[Bash shell] 纯文本查看 复制代码 include modsecurity.conf
include owasp-modsecurity-crs/crs-setup.conf
include owasp-modsecurity-crs/rules/REQUEST-900-EXCLUSION-RULES-BEFORE-CRS.conf
include owasp-modsecurity-crs/rules/REQUEST-901-INITIALIZATION.conf
Include owasp-modsecurity-crs/rules/REQUEST-903.9002-WORDPRESS-EXCLUSION-RULES.conf
include owasp-modsecurity-crs/rules/REQUEST-905-COMMON-EXCEPTIONS.conf
include owasp-modsecurity-crs/rules/REQUEST-910-IP-REPUTATION.conf
include owasp-modsecurity-crs/rules/REQUEST-911-METHOD-ENFORCEMENT.conf
include owasp-modsecurity-crs/rules/REQUEST-912-DOS-PROTECTION.conf
include owasp-modsecurity-crs/rules/REQUEST-913-SCANNER-DETECTION.conf
include owasp-modsecurity-crs/rules/REQUEST-920-PROTOCOL-ENFORCEMENT.conf
include owasp-modsecurity-crs/rules/REQUEST-921-PROTOCOL-ATTACK.conf
include owasp-modsecurity-crs/rules/REQUEST-930-APPLICATION-ATTACK-LFI.conf
include owasp-modsecurity-crs/rules/REQUEST-931-APPLICATION-ATTACK-RFI.conf
include owasp-modsecurity-crs/rules/REQUEST-932-APPLICATION-ATTACK-RCE.conf
include owasp-modsecurity-crs/rules/REQUEST-933-APPLICATION-ATTACK-PHP.conf
include owasp-modsecurity-crs/rules/REQUEST-941-APPLICATION-ATTACK-XSS.conf
include owasp-modsecurity-crs/rules/REQUEST-942-APPLICATION-ATTACK-SQLI.conf
include owasp-modsecurity-crs/rules/REQUEST-943-APPLICATION-ATTACK-SESSION-FIXATION.conf
include owasp-modsecurity-crs/rules/REQUEST-949-BLOCKING-EVALUATION.conf
include owasp-modsecurity-crs/rules/RESPONSE-950-DATA-LEAKAGES.conf
include owasp-modsecurity-crs/rules/RESPONSE-951-DATA-LEAKAGES-SQL.conf
include owasp-modsecurity-crs/rules/RESPONSE-952-DATA-LEAKAGES-JAVA.conf
include owasp-modsecurity-crs/rules/RESPONSE-953-DATA-LEAKAGES-PHP.conf
include owasp-modsecurity-crs/rules/RESPONSE-954-DATA-LEAKAGES-IIS.conf
include owasp-modsecurity-crs/rules/RESPONSE-959-BLOCKING-EVALUATION.conf
include owasp-modsecurity-crs/rules/RESPONSE-980-CORRELATION.conf
include owasp-modsecurity-crs/rules/RESPONSE-999-EXCLUSION-RULES-AFTER-CRS.conf
% Y( W. u0 ^' y3 `' w; v& }6 L6 K: h1 H6 H( C9 F$ o
注:考虑到可能对主机性能上的损耗,可以根据实际需求加入对应的漏洞的防护规则即可。
9 f8 S1 U$ O6 u. y+ z" U$ B* i$ w/ J* w& ^5 m
4 N7 {& m2 S1 }5 N. s+ I配置Nginx支持Modsecurity7 }6 H+ e2 @5 E& u6 Y7 l9 x, V
启用Modsecurity5 L$ z- D$ g* C
使用静态模块加载的配置方法
1 a! d/ ]' O, [# U在需要启用Modsecurity的主机的location下面加入下面两行即可:
, X' C T4 x3 L. ~$ D4 ?& c
7 J: x' r0 Q4 {. u% p" S1 }
9 @% @4 `: p3 }7 U3 {* ]ModSecurityEnabled on;
9 T% z. ^0 }+ `8 E! I! O1 }# WModSecurityConfig modsec_includes.conf;7 J1 N4 y# A9 {, I4 V
修改Nginx配置文件,在需要启用Modsecurity的location开启Modsecurity。2 C2 z" Q5 U V a0 ^0 c5 j! V
( v8 ~0 ~1 ?5 T+ l" ]4 Y
8 }( x+ X8 o1 e+ k8 k6 l$ vim /usr/local/nginx/conf/nginx.conf
3 @$ x5 ]* z2 m4 V7 {2 ?9 }: J+ T1 C1 _+ s7 j8 l6 k8 [
: l% X0 }8 I8 Y* f: q
server {3 H1 r6 d: A6 o/ P" J
listen 80;
4 {/ K3 ] q. s' _1 _5 } server_name example.com;1 b2 K7 w" t C$ l- E6 S0 o- H
# o. r* B1 ?4 I* B8 q; h: m% h5 t! f2 e z, x3 K) {, q
location / {
* r/ l- g r1 m ModSecurityEnabled on;
( f+ }7 o& }4 \ U ModSecurityConfig modsec_includes.conf;
4 H0 i: L9 {8 n6 g' ?/ z root html;4 {0 |; v7 G5 m3 x- t% G
index index.html index.htm;) Q" |+ W7 w6 {" j+ K( K
}# l! R, ?. c, D5 m- d1 V9 I% c6 W: \
}- o$ v/ s7 s* ]7 Y
使用动态模块加载的配置方法
$ t+ J7 H, F# Q# r0 H$ E; A% u3 Z在需要启用Modsecurity的主机的location下面加入下面两行即可:' Z+ Q# L6 [5 ~: X" E
3 d ~5 T0 R, g8 x0 N% f! \" j. Y" i5 ?) n: \3 k
modsecurity on;
1 z: J" N; k3 K' ymodsecurity_rules_file modsec_includes.conf;2 e x5 v3 S. u8 h0 i5 o
修改Nginx配置文件,在需要启用Modsecurity的location开启Modsecurity。
& N' m" l& k$ I, d, U! P, ?) K! c
/ K/ I: T# K# @6 R5 u" @* z9 Q7 @8 Y# w# d7 Y5 ?
$ vim /usr/local/nginx/conf/nginx.conf
2 p8 G$ O- J2 k- f( R/ a! E+ v6 f+ W! V0 K0 ^- A1 S% O8 p+ m
- S3 D' k7 h- D. N1 W- O, E( r' d! Cserver {! I/ d* ^4 N/ k. ~1 g2 C' B
listen 80;% w3 k; \- v" `$ w5 z
server_name localhost mike.hi-linux.com;9 Q% Z. R r0 c3 A
access_log /var/log/nginx/yourdomain.log;
! H( H4 p* \3 x+ r0 Q6 n9 \1 |" `2 [7 B/ C9 C! [
5 v; ?! T) I0 g
location / {
7 g4 H5 ?* }& k i3 j
# q0 ]2 b5 M2 j5 w# |
4 R. I$ g3 V( A modsecurity on;7 n8 _/ i8 f% E# ^+ b; p9 p5 W3 s
modsecurity_rules_file modsec_includes.conf;
# Q2 N8 F' i: @" n root html;; V5 S1 ]* x) x3 e* g
index index.html index.htm;
( t: W0 _7 k# u6 l1 w% Z$ |}9 n5 i. A4 i8 ` A5 u1 ~
}
+ g! K) [) k% ?. x7 f验证Nginx配置文件
A, D+ i! u% b: R/ R$ /usr/local/nginx/sbin/nginx -t" D+ g- J$ a' Q( n) M1 Z
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok) v( K/ B' P& X9 s3 l5 @
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful5 X3 N: k+ I- v/ |
启动Nginx/ }+ ^9 ], \" R) A( \$ P0 w" l, @
$ /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf0 g7 _1 t; y4 e
& K$ y/ {& A: H9 y2 q测试Modsecurity ModSecurity现在已经成功配置了OWASP的规则。现在我们将测试对一些最常见的Web应用攻击。来测试ModSecurity是否挡住了攻击。这里我们启用了XSS和SQL注入的过滤规则,下面的例子中不正常的请求会直接返回403。 在浏览器中访问默认首页,会看到Nginx默认的欢迎页: [/url] 这时我们在网址后面自己加上正常参数,例如: 。同样会看到Nginx默认的欢迎页: [url=http://img.colabug.com/2017/06/842f48f203c6c2cd30144f29b57af97a.png] 接下来,我们在前面正常参数的基础上再加上 ,整个请求变成: [/url] 就会看到Nginx返回403 Forbidden的信息了,说明Modsecurity成功拦截了此请求。再来看一个的例子,同样会被Modsecurity拦截。 [url=http://img.colabug.com/2017/06/246ce28e95310a32f791893d4f5c55ca.png] 查看Modsecurity日志 [url=http://img.colabug.com/2017/06/ae44dcb58b8a4a0ea761317e398b3101.png][/url] 所有命中规则的外部攻击均会存在modsec_audit.log,用户可以对这个文件中记录进行审计。Log文件位置在modsecurity.conf中SecAuditLog选项配置,Linux默认在 /var/log/modsec_audit.log 。 $ cat /usr/local/nginx/conf/modsecurity.confSecAuditLog /var/log/modsec_audit.logModsecurity主要是规则验证(验证已知漏洞),Nginx下还有另一个功能强大的WAF模块Naxsi。Naxsi最大特点是可以设置学习模式,抓取您的网站产生必要的白名单,以避免误报!Naxsi不依赖于预先定义的签名,Naxsi能够战胜更多复杂/未知/混淆的攻击模式。
. o- E" }, r3 o$ g2 x! M* U |