找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 11419|回复: 0

利用ModSecurity在Nginx上构建WAF

[复制链接]
发表于 2017-10-19 17:34:51 | 显示全部楼层 |阅读模式
ModSecurity原本是Apache上的一款开源WAF模块,可以有效的增强Web安全性。目前已经支持Nginx和IIS,配合Nginx的灵活和高效可以打造成生产级的WAF,是保护和审核Web安全的利器。0 D5 }% n" D. d
5 b3 u- B( j2 _8 t' a, h1 H' k* N
& n) R/ o7 Z) y) [0 ?. D1 W/ P
在这篇文章中,我们将学习配置ModSecurity与OWASP的核心规则集。
% o- A+ D* I, Y! z$ m! @5 {( {: V3 O9 O/ [
6 K8 R& c) S* `. Y5 s1 f4 U. b6 J
什么是ModSecurity3 g3 T$ l1 t& E
ModSecurity是一个入侵侦测与防护引擎,它主要是用于Web应用程序,所以也被称为Web应用程序防火墙(WAF)。它可以作为Web服务器的模块或是单独的应用程序来运作。ModSecurity的功能是增强Web Application 的安全性和保护Web application以避免遭受来自已知与未知的攻击。
2 }5 N$ o9 \: u. O" Z
% n* h" }0 A4 S; Y) R) o; x$ W; J, O
. n* N9 h* g* }% z3 z; VModSecurity计划是从2002年开始,后来由Breach Security Inc.收购,但Breach Security Inc.允诺ModSecurity仍旧为Open Source,并开放源代码给大家使用。最新版的ModSecurity开始支持核心规则集(Core Rule Set),CRS可用于定义旨在保护Web应用免受0day及其它安全攻击的规则。& t% x% h1 o( O8 b

/ S( d" Z* {. U. o* @# o
/ X3 ]7 _3 a& X* lModSecurity还包含了其他一些特性,如并行文本匹配、Geo IP解析和信用卡号检测等,同时还支持内容注入、自动化的规则更新和脚本等内容。此外,它还提供了一个面向Lua语言的新的API,为开发者提供一个脚本平台以实现用于保护Web应用的复杂逻辑。  y2 J6 c- Y7 Z* E& c( H

# G# S* h; @6 A" A4 m/ ]6 _) E6 V3 k
官网: https://www.modsecurity.org/
2 j" B* q5 }- e7 Z9 r. u) Y# M& [4 p; ]6 o" X8 h- o* |
6 x3 ]: S% s( \
什么是OWASP CRS
8 g) X7 ~* \: S+ jOWASP是一个安全社区,开发和维护着一套免费的应用程序保护规则,这就是所谓OWASP的ModSecurity的核心规则集(即CRS)。ModSecurity之所以强大就在于OWASP提供的规则,我们可以根据自己的需求选择不同的规则,也可以通过ModSecurity手工创建安全过滤器、定义攻击并实现主动的安全输入验证。
4 D. w2 w6 X: u3 _  K- m8 r* U& z2 o3 `. e: a; F# t6 e, o

. ]/ O6 U  a$ ZModSecurity核心规则集(CRS)提供以下类别的保护来防止攻击。: x) m9 ~$ K/ Y! [: e1 A
+ J5 E; F& p" Z: g" ~7 Y
0 E0 @6 M7 {  h' l7 V! b& h
HTTP Protection(HTTP防御)2 X5 x7 r' v- l% ^+ \: j) W4 k
HTTP协议和本地定义使用的detectsviolations策略。
( U$ Z2 c' j9 A  T% Z: G3 D5 m6 Y: f$ p  _/ N: P$ P0 D4 D8 z/ b9 F$ \

6 f2 k! X& `0 j2 V5 c, Z; WReal-time Blacklist Lookups(实时黑名单查询)4 R3 }! b1 q2 q% i! R
利用第三方IP名单。/ h8 v& y- P( q4 @3 @1 |
5 n+ t1 g; ^5 K3 A% b! T3 l$ k

7 n5 ^0 z; {2 H8 j' ^HTTP Denial of Service Protections(HTTP的拒绝服务保护)
* b$ Z4 k/ N7 H# h# ]防御HTTP的洪水攻击和HTTP Dos攻击。
1 f6 b4 J" h( f5 ]* g
( |0 u8 k8 z, P4 I: S1 w
5 Q5 |. C+ h( y( Q! v+ }; \( H6 RCommon Web Attacks Protection(常见的Web攻击防护)5 C( L8 N6 c& h0 ^( {
检测常见的Web应用程序的安全攻击。" v+ w! _* F; z' z$ _# o- [
, f1 ~5 @1 S- E& o1 {  v8 c, }5 }4 ^

+ @6 ?9 s& v0 [4 F/ [6 @Automation Detection(自动化检测)3 J( P. \" j2 b, T( F2 j
检测机器人,爬虫,扫描仪和其他表面恶意活动。
+ C, |7 N7 g$ a) g6 |2 _, b& m5 b" j2 L, b$ H3 F9 O& ]; h
: |1 F3 {2 E9 s! p
Integration with AV Scanning for File Uploads(文件上传防病毒扫描)
1 @0 z- g: e2 B, U' T$ c检测通过Web应用程序上传的恶意文件。0 n6 H4 B! a- n8 l& L/ l

# M8 R: [  ~' y7 Q# b7 r; E% t$ o1 M, R& q2 |
Tracking Sensitive Data(跟踪敏感数据)
1 `1 G, l/ R; k8 x6 o. Z信用卡通道的使用,并阻止泄漏。$ |" X6 B3 S* b2 Z

0 n5 M% q! f9 W# `
( C$ d- x' \7 O1 e& i- _5 cTrojan Protection(木马防护)$ S' O9 E3 N# _! _/ a
检测访问木马。5 M# N3 m+ n) j2 d) R. _! o8 J

1 {, G( ?3 E! M  S! x
8 q( `$ g( |- S: `Identification of Application Defects(应用程序缺陷的鉴定)' {0 s/ H1 [: _
检测应用程序的错误配置警报。4 ?/ S$ E; U4 A3 O  O" j0 S

$ V9 S! [) i' z/ U9 A
. `6 R$ [" H& H8 KError Detection and Hiding(错误检测和隐藏)4 W3 v# O1 m$ ^' X2 |3 A9 d( `
检测伪装服务器发送错误消息。
2 `: v3 r6 |# w$ y5 ^" v, p& V  m& p' z: h2 w, l: T6 X" ~2 s

- @  Y3 r9 n% E; u& }+ X安装ModSecurity8 O5 f% i/ K' f& E: q2 E& {2 A
软件基础环境准备; Y9 s, Y) [5 V0 {3 J4 N6 k
下载对应软件包2 Y& M7 `; v( S  G! i
$ cd /root
4 I3 N  A: ^' h: F$ wget 'http://nginx.org/download/nginx-1.9.2.tar.gz'
3 s1 @6 u0 u# M: M7 z' j$ wget -O modsecurity-2.9.1.tar.gz https://github.com/SpiderLabs/ModSecurity/releases/download/v2.9.1/modsecurity-2.9.1.tar.gz1 y4 P6 _) Y4 f5 B
安装Nginx和ModSecurity依赖包
  s# X, f! x% z/ L6 NCentos/RHEL% `/ z6 d$ C' y3 {- P' _5 g

- h: U+ T4 B% i1 x& x+ n' {' Q1 G9 d% a/ S. h  L1 _8 g1 t. w
$ yum install httpd-devel apr apr-util-devel apr-devel  pcre pcre-devel  libxml2 libxml2-devel zlib zlib-devel openssl openssl-devel3 o3 n; U1 d# n; _! g8 e
Ubuntu/Debian
0 `! R/ K  ~! V( O, D- A" ?2 U$ {) ^& z' j1 J: t: ]- U

. Q1 M' A, M# M( C  b$ 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++-dev% x* R9 i# a! P3 T1 G) o! r
编译安装ModSecurity, p0 Z8 v6 w( q- X
Nginx加载ModSecurity模块有两种方式:一种是编译为Nginx静态模块,一种是通过ModSecurity-Nginx Connector加载动态模块。
- r2 d. S5 G/ V5 U: U+ a0 p' R4 i6 }: x* y: _* R) }) A) B  C
( i" ]; l4 M+ M" D
方法一:编译为Nginx静态模块
1 i, k  j. u& n# m3 `- z/ p* D4 t2 t, a5 d' m/ L1 H1 _
5 h6 H$ j' N6 a; ^
编译为独立模块(modsecurity-2.9.1)
4 L7 E; C, Y- [! A: t3 V- j3 ^, i$ tar xzvf modsecurity-2.9.1.tar.gz
: s3 s) e; P# H2 a$ cd modsecurity-2.9.1/. e9 p3 Z( ~5 H
$ ./autogen.sh
" a+ R1 s! @* A$ Q$ ./configure --enable-standalone-module --disable-mlogc6 q2 r9 Z1 p! s& ^, |# x% _
$ make" G/ R. i, u+ @8 W) K8 z) n
编译安装Nginx并添加ModSecurity模块( }5 F- s7 T. B# }, Z- `( O, ^
$ tar xzvf nginx-1.9.2.tar.gz
! {% Z# R( U  ]& f1 g7 W- M$ cd nginx-1.9.2
2 U8 @! C# t: x3 N$ ./configure --add-module=/root/modsecurity-2.9.1/nginx/modsecurity/1 n# P  K- s# f0 t3 j' v7 Q
$ make && make install; z8 k, E) `7 u; c
方法二:编译通过ModSecurity-Nginx Connector加载的动态模块
( T/ z6 r8 A! v7 o  y' o5 U* D! i: u1 R9 G8 B4 z& o. }

/ f- z5 v9 h' k编译LibModSecurity(modsecurity-3.0), u+ E# ~- c2 |9 w
$ cd /root1 ^% b, @+ H# p$ U! ?
$ git clone https://github.com/SpiderLabs/ModSecurity
# `6 R) q8 `0 P3 V$ cd ModSecurity
& B1 r+ J# S  O$ git checkout -b v3/master origin/v3/master, ~% g0 z' P6 j. w) B" S  J" b
$ sh build.sh5 Z2 i/ b0 j7 P) h: u! I' P$ X
$ git submodule init4 R7 s% y+ R, y: B! D+ ]- {
$ git submodule update
. x" W; g& I( j2 N. R5 O$ ./configure
: r! E) ^7 E( _$ make$ ~/ Q/ A6 O  E" e8 ?5 r% L7 Z
$ make install
; e3 _7 ?* N: A9 r$ nLibModSecurity会安装在 /usr/local/modsecurity/lib 目录下。) Z6 H3 x2 p: ~

# t: I! V* [* h+ W  M" H, l4 q( ?' M$ ~. ~) _: x7 m
$ ls /usr/local/modsecurity/lib
1 o( m! m3 x. ^! E& J9 a9 ^% b3 Ylibmodsecurity.a  libmodsecurity.la  libmodsecurity.so  libmodsecurity.so.3  libmodsecurity.so.3.0.0( ~/ F6 w- k) `( p4 c3 s& U
编译安装Nginx并添加ModSecurity-Nginx Connector模块
) y0 |! |( d- _6 n+ ^) y# l使用ModSecurity-Nginx模块来连接LibModSecurity$ e& w" U; _( i% {

" ]& [3 U+ C* j9 t8 d: B3 O6 x/ `7 [/ [7 v" U: \1 S
$ cd /root+ X  r6 ~" F5 ^
$ git clone https://github.com/SpiderLabs/ModSecurity-nginx.git modsecurity-nginx
; {6 I* G& i6 u" }- T" e$ tar xzvf nginx-1.9.2.tar.gz3 B5 n; E' l: o  [7 c% z5 G
$ cd nginx-1.9.2
# ^0 p! q0 f9 g: H$ ./configure --add-module=/root/modsecurity-nginx
4 g5 q( B4 O- A3 ?8 [0 v$ make/ B" w7 B, s6 H9 M2 D
$ make && make install
* W% @2 i9 H' ^% ]/ T1 @添加OWASP规则6 _8 b' x, y: k
ModSecurity倾向于过滤和阻止Web危险,之所以强大就在于规则。OWASP提供的规则是社区志愿者维护的被称为核心规则CRS,规则可靠强大,当然也可以自定义规则来满足各种需求。
- }" T- V2 C+ u0 X0 R$ _/ a, W* U1 s$ Z

* I, Y0 v  ^. i! ^" }下载OWASP规则并生成配置文件
: x" A: g$ A3 p' Q  h- v' t: s# R$ git clone https://github.com/SpiderLabs/owasp-modsecurity-crs.git; {0 G. o- B. P( ]: a
$ cp -rf owasp-modsecurity-crs  /usr/local/nginx/conf/
! X) I! A+ c2 m4 H3 N6 P) e$ cd /usr/local/nginx/conf/owasp-modsecurity-crs
5 B1 M3 m* j  d5 ~) C/ ~6 m$ cp crs-setup.conf.example  crs-setup.conf
: F3 A/ Z( Z- y! k7 m. P配置OWASP规则3 ]* B) ?4 l/ Q- m( t/ [( \
编辑crs-setup.conf文件
' X6 b% z4 ^1 o+ j. ^  _; M( E. P, }7 W" K) p

7 g* G6 u& T4 [8 l# v$ sed -ie 's/SecDefaultAction "phase:1,log,auditlog,pass"/#SecDefaultAction "phase:1,log,auditlog,pass"/g' crs-setup.conf
2 a( K8 P6 Q9 ^1 u; W1 J3 }$ sed -ie 's/SecDefaultAction "phase:2,log,auditlog,pass"/#SecDefaultAction "phase:2,log,auditlog,pass"/g' crs-setup.conf
  N* G# t( g, q! B$ z' }$ sed -ie 's/#.*SecDefaultAction "phase:1,log,auditlog,deny,status:403"/SecDefaultAction "phase:1,log,auditlog,deny,status:403"/g' crs-setup.conf" g& O; b  i8 Q1 e
$ sed -ie 's/# SecDefaultAction "phase:2,log,auditlog,deny,status:403"/SecDefaultAction "phase:2,log,auditlog,deny,status:403"/g' crs-setup.conf
4 r% [& v) o" F1 p) S默认ModSecurity不会阻挡恶意连接,只会记录在Log里。修改SecDefaultAction选项,默认开启阻挡。
2 [/ f5 k5 G+ p
5 o7 G$ H' j3 B" x
6 R% J5 f" t* v8 v' x启用ModSecurity模块和CRS规则
3 X5 s$ s, f8 I复制ModSecurity源码目录下的modsecurity.conf-recommended和unicode.mapping到Nginx的conf目录下,并将modsecurity.conf-recommended重新命名为modsecurity.conf。9 Q( T1 z- v$ d! H  I

2 K" D: I8 {' n, W0 _+ e' c5 t* M6 E5 p3 D' R2 [3 C
modsecurity.conf-recommended是ModSecurity工作的主配置文件。默认情况下,它带有.recommended扩展名。要初始化ModSecurity,我们就要重命名此文件。
" p6 V5 W+ ]7 Q0 {- |- v" T0 L; l! n

& k$ z6 Z/ X+ C; P$ cd /root/modsecurity-2.9.1/$ o$ {& x& g4 d0 x. U) B+ J1 F
$ cp modsecurity.conf-recommended /usr/local/nginx/conf/modsecurity.conf    C3 q. _8 F8 i; o9 v" M- ^$ G
$ cp unicode.mapping  /usr/local/nginx/conf/4 c" r) g5 C9 U4 C- @
将SecRuleEngine设置为On,默认值为DetectOnly即为观察模式,建议大家在安装时先默认使用这个模式,规则测试完成后在设置为On,避免出现对网站、服务器某些不可知的影响。& r/ ^# f" T" z) J  e6 @* H) b0 D+ Q+ Y
) X) M5 {! t0 b# [; @% I
) }% R  ^) ?  O" U7 N  N2 }9 F
$ vim /usr/local/nginx/conf/modsecurity.conf
8 {# {+ Z) o/ N4 P0 i- s/ uSecRuleEngine On
) K* N/ j7 v0 G+ G5 c, N* C8 IModSecurity中几个常用配置说明:  V# A9 {! A/ P( A
% M- r$ {2 F2 q" I6 j+ J$ E

( O* h9 p! F! ]4 \1.SecRuleEngine:是否接受来自ModSecurity-CRS目录下的所有规则的安全规则引擎。因此,我们可以根据需求设置不同的规则。要设置不同的规则有以下几种。SecRuleEngine On:将在服务器上激活ModSecurity防火墙,它会检测并阻止该服务器上的任何恶意攻击。SecRuleEngine Detection Only:如果设置这个规则它只会检测到所有的攻击,并根据攻击产生错误,但它不会在服务器上阻止任何东西。SecRuleEngine Off:这将在服务器上上停用ModSecurity的防火墙。+ @5 r7 W2 W: i
6 b  n1 K; b. J* H1 z8 |
5 |# ~1 ?0 c% e! h( S
2.SecRequestBodyAccess:它会告诉ModSecurity是否会检查请求,它起着非常重要的作用。它只有两个参数ON或OFF。
) J: o, o) z3 \" `+ q6 c; K7 i
5 h2 i6 B) G# s5 a' y% v- a
1 P* H8 P% }: Z8 X# S6 t0 d3.SecResponseBodyAccess:如果此参数设置为ON,然后ModeSecurity可以分析服务器响应,并做适当处理。它也有只有两个参数ON和Off,我们可以根据求要进行设置。  |% b0 j- `# k

3 A' Y2 C4 E: Q4 W  y3 S. `. o/ @( J( C6 k$ M4 k6 N! E
4.SecDataDir:定义ModSecurity的工作目录,该目录将作为ModSecurity的临时目录使用。; v( h% e1 O1 E) [. k! y  p8 a  N
  O$ Q- w1 q  G. F
* }/ m, i. P' ?3 s6 [( s& e
在 owasp-modsecurity-crs/rules 下有很多定义好的规则,将需要启用的规则用Include指令添加进来就可以了。1 U! j, s/ c: y$ N7 o  ~  U
, r5 [, C! h6 F$ @/ I. H; W/ A" C

7 v" g7 i2 m2 m3.x版本CRS
8 m/ X3 g: v9 D" o/ z* \$ cd /usr/local/nginx/conf/owasp-modsecurity-crs
4 H( a' n* g1 v5 E1 H# 生成例外排除请求的配置文件" e- L/ X' x' G9 E8 D) h
$ cp rules/REQUEST-900-EXCLUSION-RULES-BEFORE-CRS.conf.example rules/REQUEST-900-EXCLUSION-RULES-BEFORE-CRS.conf
2 e4 N9 c8 m7 P. p$ cp rules/RESPONSE-999-EXCLUSION-RULES-AFTER-CRS.conf.example rules/RESPONSE-999-EXCLUSION-RULES-AFTER-CRS.conf- X' y4 A$ a( J% u
$ cp rules/*.data /usr/local/nginx/conf+ }2 {4 e* T7 H# t% z
为了保持modsecurity.conf简洁,这里新建一个modsec_includes.conf文件,内容为需要启用的规则。
& {/ e' X' z' A& L: }$ G$ X0 O6 i
0 k0 R$ R0 A7 s2 r' C+ O
* l1 H9 a; o/ `% o! d$ vim /usr/local/nginx/conf/modsec_includes.conf6 b) c8 v+ i% t5 _' I
0 b' l$ f% X) X7 `3 U* ^
[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
8 _. g5 \9 C/ p; |/ R

- x& d2 G% ?5 z  P1 |, D* u注:考虑到可能对主机性能上的损耗,可以根据实际需求加入对应的漏洞的防护规则即可。
; b' w+ v! @5 n% K1 k9 P3 M& K! f" J$ [6 M
7 ^( N3 ^+ ^/ I
配置Nginx支持Modsecurity
5 Z* \2 Y& Q9 J启用Modsecurity; Z; h; E3 j6 M# r0 M9 m& B
使用静态模块加载的配置方法; D: e3 U# N: X2 r! V! y/ u) F# C" `  F* h7 W
在需要启用Modsecurity的主机的location下面加入下面两行即可:: H2 Z1 V% M6 A3 W( i
1 g2 b$ g8 h- O6 r& D& T

1 f. B# Q6 e3 B& u5 BModSecurityEnabled on;
3 W5 w/ ?- c3 w, a4 vModSecurityConfig modsec_includes.conf;: a. ~, x# L4 g, E
修改Nginx配置文件,在需要启用Modsecurity的location开启Modsecurity。7 s- z! M( O$ p9 E# `' D. ]* K6 \

, e  R/ a' b( y* b  d. O: n' t+ c  K: M
$ vim /usr/local/nginx/conf/nginx.conf
$ @1 j. P6 \4 l  U
9 `( ~& J, x% `7 [  O" b: w1 d# @5 E# V1 f, o
server {" A; D/ @1 q5 V. \3 @- a
  listen       80;
3 _& Z+ [: ^8 q5 x' N. F1 L" T2 z  server_name  example.com;- R! H6 i4 ]: R7 E4 s( f& J
0 A4 x8 e6 h9 i6 G+ P
/ }5 d2 }  z3 H" k" f
  location / {
& A! u. {2 Q8 ^0 {/ n    ModSecurityEnabled on;, h) h/ G6 J, ^# D
    ModSecurityConfig modsec_includes.conf;
. `; f! v$ z, Y" Y6 i# ^3 J# e" h    root   html;7 H! [" h& B' y  K, k# H$ B- L: ~
    index  index.html index.htm;
; B4 O5 ~0 D- Y& h' j) I7 F2 W& G) `$ x  }2 b# `9 ?! l- B) @6 ^) |0 `; {, `
}
. _0 i, ?1 ^( h3 ~2 @$ G- e使用动态模块加载的配置方法" C+ Z& c8 L8 V; H* }
在需要启用Modsecurity的主机的location下面加入下面两行即可:
; f3 x* E, F9 M: D0 v  h
& n, s2 q! Z+ s$ M
/ b3 ]) S# Y: G" f, [  Rmodsecurity on;
' {8 w9 L9 H# ~9 L1 f+ bmodsecurity_rules_file modsec_includes.conf;
/ _/ e3 ?3 w. {( M0 d0 c0 w  ?5 S修改Nginx配置文件,在需要启用Modsecurity的location开启Modsecurity。
4 O+ W% p( X9 I! I
+ n3 [" R, c9 a) b
. i+ S% l, Z4 N1 n$ vim /usr/local/nginx/conf/nginx.conf& V) r9 B  O% Y. p; F4 {" w) ?1 g0 n$ |
: ?5 e' y7 x6 {1 \5 ~2 k' [
* t; ^; Q( q0 ?- o9 S
server {- d& B- I0 Z  T& `4 N
  listen  80;' F4 o% l4 Z, i( o3 i8 p! q
  server_name localhost mike.hi-linux.com;
! z) {- i( |" y" a" ^+ ~) o  access_log /var/log/nginx/yourdomain.log;# K7 r; i; r; r& D% z
6 C0 i1 Z3 [4 e4 U% P" ^' t

& `3 o8 Q3 C" d5 i( b( X  location / {. B+ z" U5 V0 A8 [5 ~' ?0 W

  z) g: y% z1 ]0 J9 d) u/ d" a4 M% T/ ~; e6 R! S
  modsecurity on;2 j1 G, q5 k# ^1 Q% P$ X
  modsecurity_rules_file modsec_includes.conf;1 j$ `" y* B' D' T% e
  root   html;
0 a# n" H# v" W4 u! d# o2 U6 @  index  index.html index.htm;6 K* w, Z" X0 S: }
}
$ F7 i* @& D9 a, F; K6 P}# T7 n6 d3 b' K
验证Nginx配置文件
1 P% w4 S: h7 |) Z7 P2 l4 Z  c2 A; R$ /usr/local/nginx/sbin/nginx -t/ F" g  n. ^' ?1 W' ^9 s6 a
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok) {( s8 h- R- z( z0 @4 n
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful& o, R% I5 ]0 ?
启动Nginx
0 E  |) ?! D. _2 W$ /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf* b4 M. T6 A7 Y! R* c

5 U/ ?  u: N, s- t

测试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.log

Modsecurity主要是规则验证(验证已知漏洞),Nginx下还有另一个功能强大的WAF模块Naxsi。Naxsi最大特点是可以设置学习模式,抓取您的网站产生必要的白名单,以避免误报!Naxsi不依赖于预先定义的签名,Naxsi能够战胜更多复杂/未知/混淆的攻击模式。

' b) S7 `; `8 X# W* K

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|第一站论坛 ( 蜀ICP备06004864号-6 )

GMT+8, 2026-6-9 18:43 , Processed in 0.084416 second(s), 22 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表