• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

入侵检测技术剖析(3)

发布: 2007-6-23 18:14 | 作者:   | 来源:   | 查看: 12次 | 进入软件测试论坛讨论

领测软件测试网

   
  入侵检测技术剖析
  专家系统

  用专家系统对入侵进行检测,经常是针对有特征入侵行为,是较为智能的方法。专家系统主要是运用规则进行分析,规则即知识,不同的系统与设置具有不同的规则,且规则之间往往无通用性。专家系统的建立依赖于知识库的完备性,知识库的完备性又取决于审计记录的完备性与实时性。入侵的特征抽取与表达,是入侵检测专家系统的关键。在系统实现中,将有关入侵的知识转化为if-then结构(也可以是复合结构),条件部分为入侵特征,then部分是系统防范措施。运用专家系统防范有特征入侵行为的有效性完全取决于专家系统知识库的完备性。

  实现一例

  以下是在WINDOWS2000,VB6.0环境下测试通过的对本机的木马探测及常规扫描进行监听的简单程序。

  Dim tmpstr As String '存放捕获的数据
   Dim NOW_OUT As Integer "总共出去连接的有几个Winsock

  Private Sub Command1_Click()
   ListPorts.AddItem txtADDPORT.Text '把文本框中的端口增加到列表框中
   End Sub

  Private Sub Command2_Click()
   On Error Resume Next '如出错就在下一个端口重新开始监听
   If Command2.Caption = "监听" Then
   For i = 0 To ListPorts.ListCount – 1 '如果命令框为‘监听',则初始化要监听的端口数量I
   Load Winsock1(i + 1) " 加载监听端口的winsock1数组控件
   Winsock1(i + 1).LocalPort = ListPorts.List(i) "使每一个WINSOCK数组变量对应一个端口
   Winsock1(i + 1).Listen "监听
   Next i
   Command2.Caption = "停止"
   Else
   For i = 1 To Winsock1.Count - 1
   Unload Winsock1(i)
   Next i '假如caption 为停止,则卸载WINSOCK1数组控件
   For i2 = 1 To Winsock2.Count - 1
   Unload Winsock2(i2)
   Next i2
   Command2.Caption = "监听"
   End If
   End Sub

  Private Sub Command3_Click()
   Unload Me
   End Sub
Private Sub Form_Load()
   txtLOG.Text = "日志:" & vbCrLf
   NOW_OUT = 1
   End Sub '在窗体载入时初始化日志文件和连接变量

  Private Sub Winsock1_ConnectionRequest(Index As Integer, ByVal requestID As Long)
   Load Winsock2(NOW_OUT) "加载建立连接的Winsock2数组控件
   Winsock2(NOW_OUT).Accept requestID "建立连接
   Winsock1(Index).Close
   Winsock1(Index).Listen "Winsock1继续监听
   NOW_OUT = NOW_OUT + 1 "连接的控件累加
   myAddLog "来自" & Winsock1(Index).RemoteHostIP & "连接到本地端口:" & Winsock1(Index).LocalPort "显示捕获的连接
   End Sub '在WINSOCK2建立连接的同时,WINSOCK1进行监听远程扫描本地端口

  Private Sub Winsock2_DataArrival(Index As Integer, ByVal bytesTotal As Long)
   Winsock2(Index).GetData tmpstr "通过Getdata函数捕获数据
   myAddLog "来自" & Winsock2(Index).RemoteHostIP & "的数据:" & tmpstr "显示捕获的数据
   End Sub '用WINSOCK2获取数据并加入到日志

  Sub myAddLog(tmptext As String) "加入日志
   tmptext = tmptext & vbCrLf
   txtLOG.SelStart = Len(txtLOG.Text)
   txtLOG.SelText = tmptext
   End Sub '自动增加日志内容,并高亮显示当前所捕捉到的数据

  程序说明:这是一个简单的监听程序,并不具有分析的功能,因此,它不是一个入侵检测系统,而是入侵检测系统的前半部分——数据收集。它是通过winsock(系统本身提供的组件)本身的功能,简单的实现对本地断口的监听和对到达本地的数据进行捕获。

  总结

  入侵检测作为一种积极主动地安全防护技术,提供了对内部攻击、外部攻击和误操作的实时保护,在网络系统受到危害之前拦截和响应入侵。入侵检测系统面临的最主要挑战有两个:一个是虚警率太高,一个是检测速度太慢。现有的入侵检测系统还有其他技术上的致命弱点。因此,可以这样说,入侵检测产品仍具有较大的发展空间,从技术途径来讲,除了完善常规的、传统的技术(模式识别和完整性检测)外,应重点加强统计分析的相关技术研究。

  但无论如何,入侵检测不是对所有的入侵都能够及时发现的,即使拥有当前最强大的入侵检测系统,如果不及时修补网络中的安全漏洞的话,安全也无从谈起。(完)

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网