




已阅读5页,还剩4页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
监控IP包流量摘 要 本课程设计主要是编制程序,监控网络,捕获一段时间内网络上的IP数据包,按IP数据包的源地址统计出该源地址在该时间段内发出的IP包的个数,将其写入日志文件中或用图形表示出来。程序中会用到Winpcap,它主要功能在于独立于主机协议发送和接收原始数据报。本次课程设计中用VC+实现基于Winpcap的IP数据包的捕获和统计,根据获取网络设备列表,选择正确的网卡并打开,获取子网掩码,编译、设置过滤器,捕获数据包;列出源IP地址及其相应的包数。使我们对于TCP/IP协议以及IP数据抱的格式有了进一步的了解和掌握。通过编写程序从而实现对网络中IP数据包流量的统计。 1、引言1.1 课程设计目的 本次课程设计主要是通过用VC+编程实现对网络中IP数据包流量的统计,也就是编制程序,监控网络,捕获一段时间内网络上的IP数据包,按IP数据包的源地址统计出该源地址在该时间段内发出的IP包的个数,将其写入日志文件中或用图形表示出来。同时应用Winpcap,Winpcap提供了很好的捕获网络数据包的方法,通过本次课程设计可以将VC+知识与Winpcap结合起来实现在一段时间内对IP数据包的流量进行统计,加深了对Winpcap的理解和运用能力。 1.2 课程设计的要求 (1)理解运用VC+软件实现对网络中的IP数据抱流量的统计方法和步骤。 (2)学习简单的MFC框架结构;(3)加深理解TCP/IP协议以及IP数据抱的格式;(4)提高网络编程能力,增加实际应用能力;(5)学会文献检索的基本方法和综合运用文献的能力。 1.3 设计平台 Microsoft Visual C+ 6.0 2、 设计原理 IP是ICP/IP协议体系中的网络层协议,TCP、UDP、ICMP和IGMP等其他协议都是以IP 协议为基础的。程序中用到的Winpcap是UNIX下的lipbcap移植到Windows下的产物,是Win32环境下数据包捕获的开放代码函数库。Winpcap由内核级的数据包过滤器,底层动态链接库(packet.dll)和一个高层的独立于系统的库(wpcap.dll)组成。 2.1 IP协议 IP是TCP/IP模型中的网络层协议,又称为互联网协议,是支持网间互连的数据报协议,它与TCP协议一起构成了TCP/IP协议族的核心。它提供网间连接的完善功能,包括IP数据报规定互联网范围内的IP地址格式。在因特网中IP协议是能使连接到网上的所有计算机网络实现相互通信的一套规则,规定了计算机在因特网上进行通信时应当遵守的规则。任何厂家生产的计算机系统,只要遵守IP协议就可以与因特网互连互通。IP地址具有唯一性。IP协议的特点如下: IP协议是一种不可靠、无连接的数据报传送协议。 IP协议是点对点的网络层通信协议。 IP协议向通信层隐藏了物理网络的差异。 IP协议以一种数据报的形式传输数据,每个数据报独立传输,可能通过不同路径传输,因此可能不按顺序到达目的地,或者出现重复。 2.2 关于Winpcap库 Winpcap(windows packet capture)是windows平台下一个基于windows的网络接口API库。主要为win32应用程序提供访问网络底层的能力。Winpcap的主要功能在于独立于主机协议(如TCP/IP)发送和接收原始数据报。Winpcap不能阻塞、过滤或控制其他应用程序数据报的收发,它只是监听共享网络上传送的数据报。 其功能有: 捕获原始数据包,包括在共享网络上各主机发送接收的以及相互之间交换的数据包; 在数据包发往应用程序之前,按照自定义的规则将某些特殊的数据包过滤掉; 在网络上发送原始数据包; 收集网络通信过程中的统计信息。 Winpcap是针对win32平台上的抓包和网络分析的一个架构,它包括一个核心态的包过滤器,一个底层的动态链接库(packet.dll)和一个高层的不依赖于系统的库(wpcap.dll)。它由Packet、NPF(Netgroup Packet Filter)、packet.dll、wpcap.dll、Application组成。 Winpcap提供了两个不同的库:packet.dll和wpcap.dll。前者提供了一个底层API,这些API可以直接用来访问驱动的函数;后者导出了一组更强大的与libpcap一致的高层抓包函数库,这些函数使得数据包的捕获以一种与网络硬件和操作系统无关的方式进行。 3 程序代码设计步骤 根据以上设计原理,我设计的得到流量统计程序的主要功能模块如下图: 图中,窗口初始化模块主要是查找网卡,并将所有网卡存入数组,并在自己制作的界面窗口中的网卡下拉列表中显示第0号网卡的信息。设置各个按钮的状态:“开始捕捉”、“停止”、“退出”按钮有效,“清除列表”按钮无效,“状态显示”显示空闲,“统计数据包数”显示0;捕获模块是在选择完正确的网卡后,要系统自动找到相应的网卡号,以混杂模式打开网卡、获取子网掩码、编译并设置过滤器,设置按钮的状态和状态栏的状态,最后启动线程。线程模块主要实现循环捉包并将包的源IP和对于的包数存入链表,当按下“停止”按钮时,线程结束,将链表中的源IP和对于的包数输出显示到界面中的列表中,更新状态栏。停止模块主要是当按钮按下是,立即结束线程,更新状态栏并将界面列表中的信息写入日志文件保存起来。根据流量设计程序的主要功能模块,相应的程序实现主要的代码如下: 初始化模块:BOOL CIPpackDlg:OnInitDialog()CDialog:OnInitDialog();if(pcap_findalldevs(&alldevs,errbuf)=-1) /查找网卡 MessageBox(找不到网卡!);int i;for(d=alldevs,i=0;d;d=d-next,i+) /d指向当前网卡,m_comboboxx.AddString(d-description); /下拉列表中显示网卡描述alldevi=d; /将网卡存入数组中 m_comboboxx.SetCurSel(0); /下拉列表中第一项显示0号网卡m_listcontrol.InsertColumn(0,Source IP Address,LVCFMT_LEFT,150,-1); m_listcontrol.InsertColumn(1,Packet Numbers, LVCFMT_RIGHT, 100 -1 ); GetDlgItem(IDC_BUTTON3)-EnableWindow(false); /停止按钮不可用捕获模块:void CIPpackDlg:Oncapture() char packet_filter=ip; /过滤,选择IP协议pcap_if_t *head=NULL;int i,k;k=m_comboboxx.GetCurSel();for(d=alldevs,i=0;inext,i+);head=d;/以混杂模式打开网卡 if(fp=pcap_open_live(head-name,1000,1,1000,errbuf)=NULL) coutnUnable to open the adapter.addresses!=NULL) /获取子网掩码 netmask=(struct sockaddr_in*)(head-addresses-netmask)-sin_addr.S_un.S_addr; else netmask=0xffffff; /没地址就设为c类地址 if(pcap_compile(fp,&fcode,packet_filter,1,netmask)0) coutnUnable to compile the packet filter. check the syntax.n; pcap_freealldevs(alldevs); return; if(pcap_setfilter(fp,&fcode)0) /设置过滤器 coutSetWindowText(正在捕获中.); /显示当前状态GetDlgItem(IDC_COMBO1)-EnableWindow(false); /网卡列表不可用 GetDlgItem(IDC_BUTTON1)-EnableWindow(false); /开始捕获按钮不可用 GetDlgItem(IDC_BUTTON2)-EnableWindow(true); /停止按钮变为可用CWinThread* cap; /定义线程cap=AfxBeginThread(AFX_THREADPROC)Threadcap,this); /创建线程并立即执行线程模块:UINT Threadcap(LPVOID param)CIPpackDlg * c1=(CIPpackDlg *)param;capstop=true; /信号量赋值,线程可用struct pcap_pkthdr *header; /被捕获的包存人文件时,这个结构被加在包头 const unsigned char *pkt_data; CIPpackDlg* pall=(CIPpackDlg*)(CWnd:FromHandle(AfxGetMainWnd()-m_hWnd); /获得指向主边框窗口类对象的指针int res;while(res=pcap_next_ex(c1-fp,&header,&pkt_data)=0) if(res=0) /如果超时没抓到包,则结束此次循环 continue; if(capstop=false) break; /接收到停止按钮发来的终止线程信号,终止线程 ip_header *ih; ih=(ip_header *)(pkt_data+14); /找到IP头的位置,以太头得长度为14 link.addnode(ih-saddr); /将源IP地址加入链表 long cnt=0; for(ipnode* ptemp=link.getphead();ptemp;ptemp=ptemp-pnext) /输出结果到列表 long lTemp=ptemp-getipaddress(); long r=ptemp-getcount(); cnt=cnt+r;/将存储的源IP地址输出到列表控制框中 int row =c1-m_listcontrol.InsertItem(0,inet_ntoa(*(in_addr*)&(lTemp); c1-m_listcontrol.SetItemText(row,0,inet_ntoa(*(in_addr*)&(lTemp); CString rstr; rstr.Format(%ldn,r); c1-m_listcontrol.SetItemText(row,1,rstr); CString s; s.Format(%ldn,cnt); pall-GetDlgItem(IDC_CLOCK)-SetWindowText(s); /更新“统计数据包数”状态 return 1;停止模块:void CIPpackDlg:Onstop() GetDlgItem(IDC_STATE)-SetWindowText(已停止捕获!); /显示当前状态GetDlgItem(IDC_COMBO1)-EnableWindow(true); /网卡列表可用 GetDlgItem(IDC_BUTTON1)-EnableWindow(true); /开始捕获按钮可用 GetDlgItem(IDC_BUTTON2)-EnableWindow(false); /停止按钮不可用GetDlgItem(IDC_BUTTON3)-EnableWindow(true); /清除列表按钮可用capstop=false; /发送信号,终止线程ofstream fout(login.txt,ios:app); /创建日志并记录文件 foutt捕获IP包记录如下:endl; /往日志文件写信息 fout开始时间为:; time_t tmp=time(NULL); foutctime(&tmp); /写入当前系统时间作为捕获开始时间 fout Sour IP Address tpacket numberspnext) /将输出结果写如日志 long lTemp=ptemp-getipaddress(); long r=ptemp-getcount(); foutendl inet_ntoa(*(in_addr*)&(lTemp)t; fouttgetcount()m_hWnd); /统计数据包数显示框清0CString s; s.Format(%ldn,0);pall-GetDlgItem(IDC_CLOCK)-SetWindowText(s);link.link_delete();退出程序:void CIPpackDlg:On_exit() /关闭对话框if(MessageBox(是否要退出程序?,请确认!,MB_YESNO)=IDYES) _exit(ERROR_SUCCESS);4 结果及分析 安装好WinPcap软件,在VC+界面上点击工具-选项-目录。添加Include文件夹下的所有文件和Lib下的所有内容,调试完程序无误后,直接点击运行,程序将自动保存日志文件login.txt到工程文件夹下。对界面按钮进行操作就可得到程序的运行结果. 5 出现的问题及解决方法 开始做课程设计时,程序中用到的Winpcap库文件C+中并没有,需要自己下载WinPcap.exe和WpdPack.zip,这里include和lib文件夹里的东西VC+6.0里面没有,出现error:Cannot open include file:pcap.h:No such file or directory错误,就需要添加,设置环境。具体步骤如下: 菜单栏-工具-选项(对话框)-目录,在include files 中,把winpcap开发包中的inlude文件添加进去,然后在library files 中把winpcap开发包中的lib文件添加进去。至此,Winpcap环境已部署好了不会再出错了。 接下来导致出错的是程序中的一些局部变量与全局变量,放错位置就出错。在类里定义然后在非函数里定义,虽不会报错,但都很运行时报错,出现内存溢出等问题。比如我在cippackdlg类里定义了nodelist link;,然后UINT T
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- T/CI 555-2024水环氧沥青钢渣超薄抗滑表层技术规范
- 压力管道取证培训课件
- 2025年环保科技行业清洁能源技术研发前景报告
- 2025年汽车行业无人驾驶汽车发展前景研究报告
- 2025年医疗健康产业对老龄化社会的应对策略与发展前景研究报告
- 嵩县2025年河南嵩县引进研究生学历人才78人笔试历年参考题库附带答案详解
- 南昌市2025江西南昌航空大学科技学院图书管理员招聘1人笔试历年参考题库附带答案详解
- 2025重庆某国有企业招聘财务助理实习生2人笔试参考题库附带答案详解
- 2025江西吉安市青原区两山人力资源服务有限公司招聘5人笔试参考题库附带答案详解
- 2025新疆兵团可克达拉市广电网络有限责任公司招聘4人笔试参考题库附带答案详解
- 2025年领导干部任前廉政法规知识考试题库(含答案)
- 2025年四川基层法律服务工作者执业核准考试仿真试题及答案一
- 信息技术基础教程(WPS版)课件 第3章 Windows 10 操作系统的使用
- 小鹿斑比题目及答案
- 中学知识竞赛试题及答案
- 2024超声法检测混凝土缺陷技术规程
- 2025-2030中国建筑行业供应链金融发展现状与前景分析
- 2025-2026学年人教版(2024)初中物理八年级上册教学计划及进度表
- 《民间纠纷调解》全套教学课件
- 医院环境感染监测制度
- 医院一键式报警系统建设与实施
评论
0/150
提交评论