广西经贸职业技术学院论坛

标题: 网络入侵检测系统的实现 [打印本页]

作者: 月中水    时间: 2009-10-16 02:58
标题: 网络入侵检测系统的实现
来源:比特网
; m0 }4 e! U" C+ M6 H    互联网也同时带给我们无数的宝贵资源,只等我们去开发、利用。开放源代码软件(Open Source Software)便是其中之一,免费可得的软件发布形式,使其具有广大的用户群;众多志愿者的协同开发模式使其具有卓越的兼容性;大量的网上社区弥补了缺少商业服务的不足。本文试图论述利9 ^( S* Y( X( L; W/ }) D6 a
  用互联网上免费可得的开放源代码软件实现一个完整的网络入侵检测系统的过程。
- r3 `9 ^8 f" Q# L2 }$ x系统概述+ m$ a: K6 \* o  `% t
  本系统采用三层分布式体系结构:网络入侵探测器、入侵事件数据库和基于Web的分析控制台。为了避免不必要的网络流量,本例将网络入侵探测器和入侵事件数据库整合在一台主机中,用标准浏览器异地访问主机上的Web服务器作为分析控制台,两者之间的通信采用HTTPS安全加密协议传输。
" q3 E: d! b" t* M  由于实现本系统所需的软件较多,有必要在此进行简要的说明:
# H* m, O& E/ I$ p  Snort
5 j4 r9 l7 G9 X- Q# O5 b  功能简述:网络入侵探测器;9 l$ g% ?0 b( n* W6 I! E! q
  正式网址:http://www.snort.org/% I# |! G# b6 J9 f" x7 S
  软件版本:1.8.6& M1 `% d# C" w' ~8 d0 `
  Libpcap+ R  v8 T/ B* ~/ V; V) s
  功能简述:Snort所依赖的网络抓包库;# M& P& o/ |" J7 U
  正式网址:http://www.tcpdump.org/
# [! J# X: R. |+ e' d7 }  软件版本:0.7.1
. q; [  [. g) ?$ b  MySQL
0 R6 {- `1 T* _% `9 O9 s0 @3 j  功能简述:入侵事件数据库;
( h, T8 u# v( W* F+ O  正式网址:http://www.mysql.org/
% j7 o) s! B- u2 i  软件版本:3.23.49
1 H% ~+ c( {7 e2 R3 S- B  Apache. H: W/ q% i! y% K2 Z% L5 e
  功能简述:Web服务器;, b: N6 X* M6 X5 v/ r6 m
  正式网址:http://www.apache.org/; ]2 ~! P" I) g$ {
  软件版本:1.3.244 c) }) O! A8 s% C+ n0 S* C& {
  Mod_ssl
2 z- C# \7 [) k. E+ |$ d  功能简述:为Apache提供SSL加密功能的模块;
2 ~) L9 S* s9 k" h  正式网址:http://www.modssl.org/; ?  I; F$ k: a9 u3 e3 j! `4 _$ Y
  软件版本:2.8.8
+ m1 K  \0 G6 v/ O' F; \# z2 @  OpenSSL( ]% y8 w$ E2 `$ _1 g7 M8 n- o8 X
  功能简述:开放源代码的SSL加密库,为mod_ssl所依赖;+ L- I$ z; ^5 _) i8 D* h, C
  正式网址:http://www.openssl.org/5 b9 c8 Y5 C7 Q4 K' R/ X6 z
  软件版本:0.9.6d/ j2 |9 r. Q, X" G1 V0 B
  MM' r9 d3 r9 r9 n
  功能简述:为Apache的模块提供共享内存服务;/ }0 D1 K8 Q6 S' p; V2 O) s; n
  正式网址:http://www.engelschall.com/sw/mm/1 @) y; g+ x! C4 a* M( Q
  软件版本:1.1.30 N2 h) M* T" [+ P  G* }
  PHP7 z8 d% M5 I9 ?% l0 o* i8 t# S' @! [
  功能简述:ACID的实现语言;
; U% N- j. ~6 \: T+ t8 Q& C4 _  正式网址:http://www.php.net/
8 i" x& r. ?# M3 {8 Y  软件版本:4.0.6
" U, `5 g* p; m, W" e$ A7 r  GD
4 |0 ^. V$ j' a. m0 }! ?% c+ n  功能简述:被PHP用来即时生成PNG和JPG图像的库;
  [; T& ^: h  Z, r4 Q' E$ i. f! K7 V  正式网址:http://www.boutell.com/gd/  b6 j# ?: N& _' ]1 [
  软件版本:1.8.4
, k9 F; V* _# W+ J5 O* `  ACID* U% f# I: @9 K) g( e
  功能简述:基于Web的入侵事件数据库分析控制台;1 g6 q( K: d6 ]# C! ]
  正式网址:http://www.cert.org/kb/aircert/) |; H/ |/ R* x: \8 J; ?/ {) s
  软件版本:0.9.6b21- N6 q" C: t. d6 |, T& G2 F
  ADODB
* |& E- Q( \. J  功能简述:为ACID提供便捷的数据库接口;
, V3 [  P! p0 C5 `  正式网址:http://php.weblogs.com/ADODB" Y! \# ?! u+ P. K2 Q6 u
  软件版本:2.00: \; S6 M( U" ~
  PHPlot0 T( b8 n& C, D3 I9 _
  功能简述:ACID所依赖的制图库;
; {: Y7 t) S' z' K  正式网址:http://www.phplot.com/, E' l; O. S# O+ ]' d; N
  软件版本:4.4.6! H5 q# o3 c0 s- u+ a! u4 {, A. t  g
  上述软件都是开源软件,可以直接登录相应软件的正式网站,下载源代码。此外,需要特别说明的一点是虽然本例中网络入侵检测系统所采用的系统平台是Solaris 8 for Intel Platform,但是在其它种类的系统平台上,如Linux 、OpenBSD以及Windows 2000等,其具体的实现步骤大同小异,因此就不在另行说明了。2 @* f3 C8 m. K, a
  三、 安装及配置
2 z. I% K0 s0 m2 y; Y0 O  在正式进行软件安装之前,请检查系统,确保拥有符合ANSI标准的C/C++编译器等软件开发工具。$ j: T' z3 N) [2 \& s% M3 G
  1、 安装MySQL. n! c+ O0 Z9 b7 b3 T
  首先,以超级用户的身份登录系统,创建mysql 用户和mysql用户组;
: @  Q  @8 ~+ `! m% f2 f  然后,以mysql身份登录,执行下列命令:
+ s7 w, q& y4 a5 y9 `# P( A' k  $gzip -d -c mysql-3.23.49.tar.gz | tar xvf -
! x( L. C) U: c7 ]  K  $cd mysql-3.23.492 |' C, G$ I: y# ]6 E% \- k
  $./configure
" g" W8 X0 t' L6 S4 c1 y  $make7 f7 t( |8 V* R, n* m
  $make install: j2 x6 N6 E& ?& ~" t8 _
  这样,就按照缺省配置将MySQL安装在/usr/local目录下。然后将源代码树中的缺省配置文件my.cnf拷贝到/etc目录下。接下来,以超级用户身份执行源码树中scripts目录下的可执行脚本文件mysql_install_db来创建初始数据库。用/etc/init.d/mysql.server命令启动数据库服务器后,使用/usr/local/bin/mysqladmin程序来改变数据库管理员的口令。
' [8 p( j" [" T9 @- m* G0 \( {$ Y  2、 安装Snort' Y6 h* B) j. |' H/ ^/ U$ ]& J
  首先安装Snort所依赖的库libpcap:* Q1 ]) @6 O1 O# ^- d- p+ U9 s, l& M
  #gzip -d -c libpcap-0.7.1.tar.gz | tar xvf -% q/ f' f" d2 P' U0 k& G* h1 B1 b7 w% ~9 ?
  #cd libpcap-0.7.1
! D0 o8 b1 Y( H. ?+ `  #./configure
: d: u% r' }4 G0 K' s9 j3 A% {  #make
: a% z+ {: t  }6 B( @6 A8 e3 H  #make install. d7 v7 H. P: S' [  A& k  \# |
  这样libpcap缺省地安装在/usr/local目录下。/ t9 i- z' A4 }; R' g5 L( y
  然后开始安装Snort:& ?4 S/ o1 y: a) u
  #gzip -d -c snort-1.8.6.tar.gz | tar xvf -1 ~0 m; l" _* ~( E
  #cd snort-1.8.6& b# D- M' g3 k0 |! g& {, P
  #./configure --prefix=/usr/local      --with-mysql=/usr/local  --with-libpcap-includes=/usr/local      --with-libpcap-libraries-/usr/local
) V8 c7 l1 q! N  #make
. p5 ]! Y4 y# f" b: \' O$ T  #make install  `1 i4 `. {. X% T
  安装完毕后,将源码树中的snort.conf文件、classification.config文件和规则文件(*.rules)拷贝到系统的/etc目录下。
* J2 A) M& X, k9 B9 s2 |$ n# d  按照下列步骤配置Snort将其捕获的网络信息输出到MySQL数据库:
4 l6 C1 t7 N+ N2 T0 g; u  Y2 r  1) 创建Snort入侵事件数据库和存档数据库:
7 t! t3 t4 t2 [. r$ v# L8 o  #/usr/local/bin/mysqladmin -u root -p create snort! L% X, E+ s' z/ u2 ~
  #/usr/local/bin/mysqladmin -u root -p create snort_archive9 M& F$ S& D5 v
  2) 执行Snort源码树下contrib目录下的create_mysql SQL脚本文件创建相关表:
6 Y/ M/ \9 K- ]0 @' L  #/usr/local/bin/mysql -u root -D snort -p < create_mysql; g0 ?& A/ W! M5 m
  #/usr/local/bin/mysql -u root -D snort_archive -p < create_mysql
2 C* E/ A9 j  S: [. q5 V7 K  3) 编辑/etc/snort.conf文件在output plugin 段中加入如下一行:
: C- ?; P: G0 p6 a$ w  output database: alert, mysql, user=root password=abc123
* X, i  u( B4 |+ ^' }  dbname=snort host=localhost. d$ F" X* e  u
  3、 安装Apache
! v! u% r9 c) [6 Q  1) 安装MM库' k, U. U# o* W4 K" |$ F  j3 M7 ]/ e# }
  #gzip -d -c mm-1.1.3.tar.gz | tar xvf -
8 _7 d- |6 _3 s8 Q( t  #cd mm-1.1.3, N* Y( Y! t, P  v) M3 h% g: c* J
  #./configure
7 E! [1 G1 G% U" Q6 s: y) |  #make7 k/ r* `9 I3 J
  #make install$ K- Y% i) [8 f* x4 n& e, O! }
  MM库被按照缺省配置安装在/usr/local目录下。1 X9 E% o1 w0 U( C$ E& G' O
  2) 安装OpenSSL- F2 N: z3 J- z- X2 Y2 L3 J+ Y  x
  #gzip -d -c openssl-0.9.6d.tar.gz | tar xvf -
8 X4 I; s0 R* m# d' B  #cd openssl-0.9.6d3 O6 H9 r- G4 p
  #./config
$ j1 O$ d1 P& w# j" c  #make
, B) C5 _% c& k; Q& [+ a3 b; I2 y& X  #make test0 y" K6 n: `, i
  #make install7 ?) F5 L. \! x
  OpenSSL按照缺省设置安装在/usr/local目录下。
3 b- X) N, v. j) }3 H! y  3) 为Apache扩展mod_ssl代码
2 V# Q2 \3 A* y; Y  #gzip -d -c apache-1.3.24.tar.gz | tar xvf -
3 r: n& y9 D. N: D- c  #gzip -d -c mod_ssl-2.8.8-1.3.24.tar.gz | tar xvf -
6 K8 e& ^# `) d- z2 |  #cd mod_ssl-2.8.8-1.3.248 g& t+ s  f! H' N
  #./configure --with-apache=apache-1.3.244 `% C8 ]' p" ]
  该命令运行成功之后,会有提示说明已经成功扩展了Apache的源代码。" V9 j  a7 m- @5 `/ X5 L) Y
  4) 安装Apache
7 {# f# M! h4 _5 m; X  #cd ../apache-1.3.240 F1 B/ U: D0 z/ {; l6 n- q8 F
  #SSL_BASE=/usr/local EAPI_MM=/usr/local ./configure -enable-module=so      --enable-module=ssl      --prefix=/usr/local
: @3 X, `* {  |  #make
+ \4 P1 F) z# Q2 J( K  #make certificate6 [  \  e8 q4 o
  #make install
; W, X$ U4 U: f: r& r8 W' ?9 F6 K4 H6 ]  其中,make certificate命令是为mod_ssl生成所需的安全证书,按照提示输入相应信息即可。这样,Apache就被安装在了/usr/local目录下。
" t6 p4 M5 J2 n$ l1 [, I  4、 安装PHP! U, n8 C8 }! v' ?, q! U
  首先安装为PHP提供既时生成PNG和JPG图象功能的GD库:, f$ {8 i1 L3 X. K) `6 e
  #gzip -d -c gd-1.8.4.tar.gz | tar xvf -
$ _$ z: l5 C. Q5 a6 m& T: ~. o/ g  #cd gd-1.8.4
) r9 b' ?, ]& e. K' p+ A  #make
' T7 ~1 w: H5 v2 j& O1 ~  #make install
, t5 g/ \2 ?9 I. K) ?! n  按照缺省配置,将其安装到/usr/local目录下。接下来开始正式安装PHP:
5 F2 B  N8 r% [  #gzip -d -c php-4.0.6.tar.gz | tar xvf -
0 ^! m! C  V/ o  #cd php-4.0.64 y! x1 u5 y5 @3 ^2 y
  #./configure -with-mysql=/usr/local      --with-apxs=/usr/local/bin/apxs      --with-gd=/usr/local
/ [+ l# O/ ~- n% w2 w9 d$ [$ X  #make, f2 X/ }2 j7 L# b) ]  ?
  #make install
- c, ]& w: v% B3 Z" S5 `  此处采用的是PHP的Apache动态模块DSO安装模式,完成之后,将会在/usr/local/libexec目录下生成Apache DSO模块libphp4.so。




欢迎光临 广西经贸职业技术学院论坛 (http://gxjmbbs.com/) Powered by Discuz! X3.2