




已阅读5页,还剩10页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
ip数据报流量统计摘 要 本课程设计主要是编制程序,监控网络,捕获一段时间内网络上的ip数据包,按ip数据包的源地址统计出该源地址在该时间段内发出的ip包的个数,将其写入日志文件中或用图形表示出来。程序中会用到winpcap,它主要功能在于独立于主机协议发送和接收原始数据报。本次课程设计中用vc+实现基于winpcap的网络数据包的捕获和统计,基于winpcap的应用程序将根据获取网络设备列表;选择网卡并打开;设置过滤器;捕获数据包或者发送数据包;列出网卡列表,让用户选择可用的网卡的步骤进行编写,同时对于tcp/ip协议以及ip数据抱的格式有了进一步的了解和掌握。通过编写程序从而实现对网络中ip数据包流量的统计。 关键词 ip数据包;流量统计;winpcap;vc+ 1 引 言 随着internet技术的发展,基于ip协议的应用成为网络技术研究与软件开发的一个重要基础,因此学习网络层以基本概念,了解ip协议的基本内容,对于掌握tcp/ip协议的主要内容和网络课程的学习是十分重要的,通过本次课程设计,有助于熟悉ip数据包格式并加深对ip协议的理解。 1.1 课程设计目的 本次课程设计主要是通过用vc+编程实现对网络中ip数据包流量的统计,实际上是编制程序,监控网络,捕获一段时间内网络上的ip数据包,按ip数据包的源地址统计出该源地址在该时间段内发出的ip包的个数,同时应用winpcap,winpcap提供了很好的捕获网络数据包的方法,通过本次课程设计可以将vc+知识与winpcap结合起来实现在一段时间内对ip数据包的流量进行统计。加深了对winpcap的理解和运用能力,同时也增长了知识,开阔了视野,对于以后的学习有很大的帮助。 1.2 课程设计的要求 (1)理解运用vc+软件实现对网络中的ip数据抱流量的统计方法和步骤。 (2)学会文献检索的基本方法和综合运用文献的能力。 (3)通过课程设计培养严谨的科学态度,认真的工作作风。 1.3 设计平台 microsoft visual c+ 6.0 2 设计原理 ip是icp/ip协议体系中的网络层协议,tcp、udp、icmp和igmp等其他协议都是以ip 协议为基础的1。程序中用到的winpcap是 windows packet capture的缩写,这是unix下的lipbcap移植到windows下的产物,是win32环境下数据包捕获的开放代码函数库。winpcap由内核级的数据包过滤器,底层动态链接库(packet.dll)和一个高层的独立于系统的库(wpcap.dll)组成。 2.1 ip协议 ip是tcp/ip模型中的网络层协议,又称为互联网协议,是支持网间互连的数据报协议,它与tcp协议一起构成了tcp/ip协议族的核心。它提供网间连接的完善功能,包括ip数据报规定互联网范围内的ip地址格式2。在因特网中ip协议是能使连接到网上的所有计算机网络实现相互通信的一套规则,规定了计算机在因特网上进行通信时应当遵守的规则。任何厂家生产的计算机系统,只要遵守ip协议就可以与因特网互连互通。ip地址具有唯一性,根据用户性质的不同,可以分为不同的类别。 ip协议的特点如下: ip协议是一种不可靠、无连接的数据报传送协议。 ip协议是点对点的网络层通信协议。 ip协议向通信层隐藏了物理网络的差异。 ip协议以一种数据报的形式传输数据,每个数据报独立传输,可能通过不同路径传输,因此可能不按顺序到达目的地,或者出现重复。 2.2 关于winpcap库 winpcap(windows packet capture)是windows平台下一个买费的、公共的基于windows的网络接口api库。主要为win32应用程序提供访问网络底层的能力。winpcap的主要功能在于独立于主机协议(如tcp/ip)发送和接收原始数据报。也就是说,winpcap不能阻塞、过滤或控制其他应用程序数据报的收发,它只是监听共享网络上传送的数据报。因此,它不能用于qos调度程序或个人防火墙。其功能有: 捕获原始数据包,包括在共享网络上各主机发送接收的以及相互之间交换的数据包; 在数据包发往应用程序之前,按照自定义的规则将某些特殊的数据包过滤掉; 在网络上发送原始数据包; 收集网络通信过程中的统计信息。 winpcap是针对win32平台上的抓包和网络分析的一个架构,它包括一个核心态的包过滤器,一个底层的动态链接库(packet.dll)和一个高层的不依赖于系统的库(wpcap.dll)。它由packet、npf(netgroup packet filter)、packet.dll、wpcap.dll、application组成,首先,抓包系统必须绕过操作系统的协议来访问在网络上传输的原始数据包,这就要求一部分运行在操作系统核心内部,直接与网络接口驱动交互。这个部分是系统依赖的,在winpcap的解决方案里它被认为是一个设备驱动,称作npf。其次,抓包系统必须有用户级的程序接口,通过这些接口,用户程序可以利用内核驱动提供的高级特性。winpcap提供了两个不同的库:packet.dll和wpcap.dll。前者提供了一个底层api,伴随着一个独立于microsoft操作系统的编程接口,这些api可以直接用来访问驱动的函数;后者导出了一组更强大的与libpcap一致的高层抓包函数库。这些函数使得数据包的捕获以一种与网络硬件和操作系统无关的方式进行。 3 程序代码设计步骤 根据以上设计原理可以得到流量统计程序的主要功能模块如下图1: 图 1 流量统计程序的主要功能 图中取得网络适配器列表主要是得到网卡的相关信息,即网卡的个数、连接情况等,选择要监听的网络适配器就是要用户选择网卡,编译并设置过滤器是为了只捕获网络数据流的某些数据,将网络适配器设置为统计模式就是接受所有经过网卡的数据包,包括不是发给本机的数据包,接下来的任务就是开始主循环调用回调函数来显示网络流量了。 根据流量设计程序的主要功能,相应的算法如下: 取得当前网络设备列表; 将用户选择的网卡以混杂模式打开,以接收到所有的数据包; 设置过滤器; 捕获ip数据包的源地址进行统计(用链表结构进行实现)。 根据以上算法得到的程序流程图如图2: 图2 程序流程图 图中获取网卡列表是为了得到网卡的相关信息,以便于用户进行选择,选取ethermet网卡是用户所选择的网卡类型,编译设置过滤器是为了编译并设置过滤器是为了只捕获网络数据流的某些数据,打开网卡既将网卡设置为混杂(统计)模式是为了接受所有经过网卡的数据包,包括不是发给本机的数据包,开始主循环以是否超时为判断条件,循环体内主要有捕获ip 数据包、将ip包的源地址加入链表、条件判断,循环结束后输出链表内容,程序至此结束。 现将其每一步的具体步骤简述如下: 3.1取得网络适配器列表 /取得网络适配器列表步骤中,alldevs是pcap_if_it指针,指向链表头,errbuf是char类型数组,存储错误信息3。 pcap_findalldevs(&alldevs,errbuf); cout”网络适配器列表:”next) cout+i:description) coutdescription; else coutno description available!n; 3.2 指定要监听的网络适配器并打开 cout”输入要监听的网络适配器号:”inum; for(d=alldevs,i=0;inext,i+); fp=pcap_open_live(d-name,65536,1,1000,errbuf); 3.3 编译并设置过滤器 /编译过滤器,fp指向打开的网络适配器,fcode为编译完成后的过滤器存储地址,“tcp“给出了过滤条件,下一个参数表示是否被优化(0为false,1为true),最后一个参数给出了子网掩码。 pcap_compile(fp,&fcode,”tcp”,1,netmask) pcap_setfilter(fp,&fcode) 3.4 设置网络适配器为统计模式 if(pcap_setmode(fp,mode_stat)0) coutts.tv_sec-old_ts-tv_sec)*1000000-old_ts-tv_usec+header-ts.tv_usec; /获得每秒的比特数 bps.quadpart=(*(longlong*)(pkt_data+8)*8*1000000)/(delay); /获得每秒的数据包数 pps.quadpart=(*(longlong*)(pkt_data)*1000000)/(delay); /将时间戳转变位可读的标准格式 ltime=localtime(&header-ts.tv_sec); strftime(timestr,sizeof timestr,%h:%m:%s,ltime); /print timestamp printf(%s,timestr); /print the samples printf(bps=%i64u,bps.quadpart); printf(pps=%i64un,pps.quadpart); /store current timestamp old_ts-tv_sec=header-ts.tv_sec; old_ts-tv_usec=header-ts.tv_usec; ; 4 结果及分析 安装好winpcap软件,在vc+界面上点击工具-选项-目录。添加include文件夹下的所有文件和lib下的所有内容,调试完程序无误后,点击开始运行“cmd”进入目标文件夹debug下运行ipi.exe文件并加入参数2 bl.txt。此时程序会检测电脑系统中的网卡数,然后选择程序运行时的网络接口,耐心等待两分钟后就会得到程序的运行结果. 图3 系统中网络接口数 图3为程序运行之后系统中的网络接口数。 图4 选择第三个网络接口 图4为选择第三个网络接口的命令行。 图5 两分钟之后捕获的ip地址和数据包 图5为程序运行后两分钟之后捕获的ip 地址和数据包的信息。 5 出现的问题及解决方法 在刚开始做此课程设计的时候我只编写了主程序代码,并没有建立工程,后来通过查找资料及文献才知道要建立一个c+应用工程,而且程序中用到的winpcap库文件c+中并没有,需要自己下载winpcap_4_1_1.exe和wpdpack_4_1_1.zip,前者是winpcap的开发程序,后者是inlude文件和lib文件,这些都是需要自己手动添加的,这里include和lib文件夹里的东西vc+6.0里面没有,出现error:cannot open include file:pcap.h:no such file or directory这个问题,就需要添加。具体步骤如下: 第一步: 点菜单栏上的“工具“,再点击下拉菜单中的”选项“对话框 把winpcap开发包里面的lib文件添加进去。 第二步: 点击菜单栏里的工程设置,选择连接 在对象/库模块中输入wpcap.lib和packet.lib,再点c/c+ 在“预处理程序定义”下输入wpcap和have_remote,要用逗号隔开。 至此,winpcap环境已部署好了不会再出错了。 接下来出错的是程序中的一些函数的参数,比如说int pcap_compile(pcap_t *p, struct bpf_program *fp,char *str,int optimize, bpf_u_int32 netmask),int pcap_setfilter(pcap_t *p, struct bpf_program *fp)函数的参数在程序编译的时候会报错,通过搜集资料及与同学交流初步更正了错误,但是程序并不是很顺利地运行出来。 6 结束语 为期两周的课程设计在老师和自己的努力下很快地结束了,在此期间老师给了我们很大的帮助,老师的认真负责让我们不再马马乎乎对待自己的学业,在课堂上老师也以同样的责任心来督促我们认真学习,对于不懂的问题都会一一解答,现在也如此,这对于我们以后步入社会之后有很大的帮助,无论做任何事情都要认真负责,对自己负责同时也对别人负责。 在老师的指导之余我还认真学习了其它课本上未曾提到过的知识,比如说网络编程方面的知识,这是我们以前所没有接触过的,虽然说这给了我们很大的一个问题但是也同时给了我们一个很好的挑战自己的机会,以前从未听过winpcap,现在我知道了它对于捕获网络上的一些数据信息很有帮助,从而丰富了我的知识,同时也知道了如何去利用它来为自己服务,这是一个很大的进步。 在自己查找资料的同时也锻炼了我及时捕获有用知识的能力,我想这是我现在乃至以后最大的一个财富,一个人最重要的就是要懂得如何去学,学习不是被动的,而是主动的,只有这样我们才能学得到对于我们自己有帮助的东西,用vc+编程实现ip数据报流量统计,开始这对于我来说是是一个很模糊的概念,但是当我在查找了很多资料之后我不再迷茫,而是慢慢跟着我所要找的资料来靠近我所要达到的目标。这是我们每个人所要学会的。 这次的课程设计也使我意识到了理论与实践相结合的重要作用,学习到知识应该应用到实践中。在此次的课程设计过程中,熟悉ip包格式和加深对ip协议的理解,告诉我们要不断地学习计算机方面的知识,精益求精,如今是信息化的时代,在internet相当发达的今天,网络编程技术也变的越来越重要,我们更应不断地提高自己的水平,在每次的程序中能够有更多的领悟。也让自己在程序的编译和应用上可以有更大一步的提高。要更好的学习计算机网络和其他方便的有关知识,做到精益求精。 了解ip协议的基本内容,对于掌握tcp/ip协议的主要内容和学习网络课程是十分重要的,通过本次课程设计,有助于熟悉ip包格式和加深对ip协议的理解。学好计算机及各种汇编语言会使我们受益匪浅。 在这两周的课程设计中我学到了很多知识,首先,要有理论做实践的指导才会很快很好地达到自己的目的,而且勤于学习和思考是一个很好的习惯,要将知识学得很扎实才会灵活运用,这同时也是我们所必须的,一切新科技的发现都是这样的;再次,一切事情都要勤于向有经验的人取经,这样才能少走弯路;最后,要珍惜和同学一起讨论和思考的机会,自己的同学是自己最好的帮手,在讨论和争辩中往往会使自己有了很好的想法。 虽然课程设计结束了,但是我们的学习还没结束,对知识的进一步学习还需要继续。 参考文献 1 谢希仁.计算机网络(第五版).北京:电子工业出版社,2009 2 佟震亚.现代计算机网络教程(第二版).北京:电子工业出版社,2003 3 周霭如.c+程序设计基础(第二版).北京:电子工业出版社,2008 4 孟威,刘慧宁.c+程序设计教程(第三版).北京:机械工业出版社,2009 附录1:ip包头部结构 sruct ip_header unsigned char ver_ihl; /版本号(4位)+头部长度(4位) unsigned char tos; /服务类型 unsigned short tlen; /总长度 unsigned short identification; /标识 unsigned short flags_fo; /标志+片偏移 unsigned char ttl; /生存时间 unsigned char proto; /协议 unsigned short crc; /校验和 dword saddr; /源地址 dword daddr; /目的地址 unsigned int op_pad /选项+填充 ; 附录2: ip结点类,存放ip包的源ip地址和其发送数据包个数 class ipnode private: long m_lipaddress; long m_lcount; public: ipnode *pnext; /构造函数 ipnode(long sourceip) m_lipaddress=sourceip; m_lcount=1; /数据包个数加1 void addcount() m_lcount+; /返回数据包个数 long getcount() return m_lcount; /返回ip地址 long getipaddress() return m_lipaddress; ; /结点链表 class nodelist ipnode *phead; ipnode *ptail; public: nodelist() phead=ptail=null; nodelist() if(phead!=null) ipnode *ptemp=phead; phead=phead-pnext; delete ptemp; /ip结点加入链表 void addnode(long sourceip) if(phead=null) ptail=new ipnode(sourceip); phead=ptail; ptail-pnext=null; else for(ipnode *ptemp=phead;ptemp;ptemp=ptemp-pnext) if(ptemp-getipaddress()=sourceip) ptemp-addcount(); break; /如果链表中没有此ip,则加入链表 if(ptemp=null) ptail-pnext=new ipnode(sourceip); ptail=ptail-pnext; ptail-pnext=null; ; 附录3:部分主程序 void main() /取得网络适配器列表,winpcap提供了pcap_findalldevs_ex() 函数来实现该功能: /它返回一个pcap_if结构的链表,每个这样的结构都包含了一个适配器的详细信息。 pcap_if_t *alldevs; pcap_if_t *d; int i=0; char errbufpcap_errbuf_size; pcap_t *fp = null; struct bpf_program fcode; bpf_u_int32 netmask; int pcap_compile(pcap_t *p, struct bpf_program *fp,char *str,int optimize, bpf_u_int32 netmask); int pcap_setfilter(pcap_t *p, struct bpf_program *fp); / 获取本地机器设备列表 if (pcap_findalldevs_ex(pcap_src_if_string, null /* auth is not needed */, &alldevs, errbuf) = -1) coutstderrerror pca
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 高级文秘类:武汉律协面试题库精 编职位资料库
- 生理学课程讲解
- 甘肃省宁县二中2026届化学高三第一学期期中达标测试试题含解析
- 体检项目病症解读
- 采购主任中层岗位竞聘动态
- 无血清培养技术
- 血液病抗菌药物临床应用指南
- 2026届北京市西城区北京市第四中学化学高一第一学期期中预测试题含解析
- 涉税资料管理规定解读
- 细胞示踪技术研究进展
- 全国中学教师《初中数学》说课教学比赛-主题:《等腰三角形的性质》说课-一等奖课件
- 回顾长征路课件
- 为什么你的学生不思考?主题班会分享
- 医疗废物交接登记表(诊所、医务室、卫生所等)
- 气雾培技术行业市场突围建议书
- 2025届云南省施甸县第一中学物理高一下期末学业水平测试试题含解析
- python程序设计-说课
- ISO15614-1 2017 金属材料焊接工艺规程及评定(中文版)
- 学生床上用品采购投标方案(技术方案)
- 2023年河南省中考数学试卷及答案
- 热力公司招聘考试笔试真题
评论
0/150
提交评论