计算机应用 | 古代文学 | 市场营销 | 生命科学 | 交通物流 | 财务管理 | 历史学 | 毕业 | 哲学 | 政治 | 财税 | 经济 | 金融 | 审计 | 法学 | 护理学 | 国际经济与贸易
计算机软件 | 新闻传播 | 电子商务 | 土木工程 | 临床医学 | 旅游管理 | 建筑学 | 文学 | 化学 | 数学 | 物理 | 地理 | 理工 | 生命 | 文化 | 企业管理 | 电子信息工程
计算机网络 | 语言文学 | 信息安全 | 工程力学 | 工商管理 | 经济管理 | 计算机 | 机电 | 材料 | 医学 | 药学 | 会计 | 硕士 | 法律 | MBA
现当代文学 | 英美文学 | 通讯工程 | 网络工程 | 行政管理 | 公共管理 | 自动化 | 艺术 | 音乐 | 舞蹈 | 美术 | 本科 | 教育 | 英语 |

免费个人入侵检测系统的实现(一)毕业论(7)

2013-06-27 01:18
导读:ne TH_FLAGS (TH_FIN|TH_SYN|TH_RST|TH_ACK|TH_URG|TH_ECE|TH_CWR) USHORT th_win; //16位窗口大小 USHORT th_sum; //16位TCP检验和 USHORT th_urp; //16位紧急指针 }tcphdr; 分析数据包模块实现
ne    TH_FLAGS    (TH_FIN|TH_SYN|TH_RST|TH_ACK|TH_URG|TH_ECE|TH_CWR)
     USHORT    th_win;            //16位窗口大小
     USHORT    th_sum;            //16位TCP检验和
     USHORT    th_urp;            //16位紧急指针
 }tcphdr;
 分析数据包模块实现
 系统采用异常检测分析方法。对每一个进入的源IP地址作时间溢出判定,如果时间没有溢出,根据捕获信息,更新记录信息。否则,清空记录信息并重新记录。当记录信息中的规则变量超过规定值时,推测有异常行为。本系统实现了端口扫描和SYN洪水攻击的检测。
 typedef struct tagrule{          // SYN洪水攻击的数据结构 
 struct ip_address keyword;   // 记录源IP地址
 time_t t1_tmpbuf_com;  // IP地址进入时间
   int count;                 // 记录某人连接我时SYN=1的次数
 }synrule;
 typedef struct tagrule2{         // 端口扫描的数据结构
  struct ip_address keyword;    // 记录源IP地址
 time_t t2_tmpbuf_com;   // IP地址进入时间
  int count[NUM2];           // 记录某人当前扫描我的端口
  int k;   
 }scnrule;
 int scanport(ip_header *ih,int dport,int timeout,time_t t_tmpbuf_now,rule2 scanrule[])               //检测端口扫描的规则函数

内容来自www.nseac.com


 {  
  int h;
  int m;
  h=0;
  if(timeout<=0)
  {
   for(h=0;h<i&&h<NUM2;h++)//查询进入的IP是否曾经出现
   {
    if( ih->saddr.byte1==scanrule[h].keyword.byte1&&
     ih->saddr.byte2==scanrule[h].keyword.byte2&&
     ih->saddr.byte3==scanrule[h].keyword.byte3&&
     ih->saddr.byte4==scanrule[h].keyword.byte4)
    {
         t_tmpbuf_add=t_tmpbuf_now-scanrule[h].t2_tmpbuf_com;
     if (t_tmpbuf_add>30)
     {
      printf("The time is out: %ld\n",t_tmpbuf_add);
      scanrule[h].k=0;
      scanrule[h].count[scanrule[h].k]=dport;
      scanrule[h].k++;
      scanrule[h].t2_tmpbuf_com=t_tmpbuf_now;
      return scanrule[h].k;
     }
     for(m=0;m<scanrule[h].k;m++)
     {
      if(scanrule[h].count[m]==dport) //0表示存在
      {
    &
上一篇:免费手机吞吃蛇游戏的设计与开发(一)毕 下一篇:没有了