计算机网络课程设计报告-解析ARP数据包含C++源码

上传人:494895****12427 文档编号:69303580 上传时间:2022-04-05 格式:DOC 页数:11 大小:73KB
返回 下载 相关 举报
计算机网络课程设计报告-解析ARP数据包含C++源码_第1页
第1页 / 共11页
计算机网络课程设计报告-解析ARP数据包含C++源码_第2页
第2页 / 共11页
计算机网络课程设计报告-解析ARP数据包含C++源码_第3页
第3页 / 共11页
点击查看更多>>
资源描述
精选优质文档-倾情为你奉上课程设计任务书学院计算机科学与技术学院专业通信工程学生姓名学号设计题目解析ARP数据包内容及要求:1. 本课程以教师讲授和学生自学同步的方式进行,学校可提供上机操作,提高实际操作,设计能力。主要功能为设计程序,实现程序2. 在完成基本技巧的讲解后,学号尾号相同的同学自行分成一组,布置不同的题目。学生独立完成3. 教师面对面当场检查学生掌握程序情况,根据学生的学习情况及题目的完成情况评定成绩。进度安排:第一阶段:在学校计算机房掌握Visual C+6.0的基本使用。第二阶段:学生自己解决上机,安装软件,自己在杂志,专业资料上参考,完成调试运行并打印出来,添加封面,完成课程设计。指导教师(签字): 年 月 日学院院长(签字): 年 月 日目录1. 课程设计目的22. 课程设计要求23. 相关知识21) ARP数据报的消息格式32) ARP协议的工作流程.44. 课程设计分析.51) 课程设计中的重点及难点.52) 参考算法.63) 核心代码.75. 相关扩展86. 心得体会107. 参考文献11一、 课程设计目的: 本课程设计的目的是对网络上的ARP数据包进行解析,从而熟悉ARP数据包的结构,对ARP协议有更好的理解和认识。二、 课程设计要求: 通过编制程序,获取网络中的ARP数据包,解析数据包的内容,将结果显示在标准输出上,并同时写入日志文件。程序的具体要求如下所示:1,以命令行的形式运行,如下所示:arpparse logfile其中,arpparse为程序名;为日志文件名。,程序输出内容如下所示:源地址 源地址 目的地址 操作时间各部分的说明如下所示:源IP地址:输出ARP消息格式中的源IP地址字段源MAC地址:输出ARP消息格式中的源物理地址字段目的IP地址:输出ARP消息格式中的目的IP地址字段。目的MAC地址:输出ARP消息格式中的目的物理地址字段操作:输出ARP消息格式中的操作字段,若为ARP请求,则为1,若为ARP应答,则为2,时间:该ARP包产生的时间3,当程序接收到键盘输入Ctrl+C时字段三、 相关知识a) ARP数据报的消息格式网络上的每台主机或设备都有一个或多个IP地址。IP地址是网络层的地址,在网络层,数据被组装成IP包。但是发送IP包需要物理设备的支持(通常是Ethernet设备,在本课程设计中我们指定为Ethernet设备),即发送端必须知道目的物理地址才能将IP包发送出去,所以需要一种将IP地址映射为物理地址的机制。ARP协议就是用来完成这个任务的。ARP协议能够在同一个物理网络中,在给定目的主机或设备的IP地址的条件下,得到目的主机或设备的物理地址。ARP协议的数据包格式如图所示: 0 8 16 24 31(位) 硬件类型 协议类型物理地址长度协议地址长度 操作 源物理地址(八位组03) 源物理地址(八位组45) 源IP地址(八位组01) 源IP地址(八位组23) 目的物理地址(八位组01) 目的物理地址(八位组25) 目的IP地址(八位组03)ARP数据包的消息格式下面对数据包的各个部分进行说明l 硬件类型:指定硬件接口类型。例如,值为1表示Ethernetl 协议类型:指定发送方支持的上层协议的类型l 物理地址长度:指定物理(硬件)地址的长度l 协议地址长度:网络层协议的地址长度。若为IP协议,其值为4l 操作:指定ARP的操作类型,例如,1表示ARP请求,2表示ARP应答l 源物理地址:指定发送方的IP地址l 目的物理地址:指定目的物理地址。l 目的IP地址:指定目的IP地址ARP分组必须在数据链路层中被封装成侦,才能发送出去封装形式如图所示ARP消息帧头部 帧数据 将ARP数据包封装成一个帧b)ARP协议的工作流程。1) 在发送一个ARP分组之前,源主机首先根据目的IP地址,在本地ARP高速缓存表中查找与之对应的目的物理地址。如果找到对应的物理地址,就不用进行地址解析,否则需要进行地址解析。2) 实现地址解析的第一步是产生ARP请求分组。在相应的字段写入本地主机的源物理地址、源IP地址,在目的物理地址字段写入0,并在操作字段写入1。3) 将ARP分组发送到本地的数据链路层,并封装成帧。以源物理地址作为源地址,以物理广播地址(FF-FF-FF-FF-FF-FF)作为目的地址,通过物理层发送出去。4) 由于采用了广播地址,因此网段内所有的主机或设备都能接受到该帧。除了目的主机外,所有接受到该分组的主机和设备都会丢弃该分组,因为目的主机能够识别ARP消息中的目的IP地址。5) 目的主机发送ARP应答分组。在ARP应答分组中,以请求分组中源物理地址、源IP地址作为其目的物理地址、目的IP地址,并将目的主机自身的物理地址、IP地址填入应答分组的源物理地址、源IP地址字段,并在操作字段中写入2。该分组通过数据链路层以点对点的方式发送出去(因为现在目的方已经知道双方的物理地址)。6) 源结点接收到ARP应答分组,知道对应于目的IP地址的目的物理地址,将它作为一条新记录加入到ARP高速缓存表。7) 源结点将有完整源IP地址、源物理地址、目的IP地址、目的物理地址的信息和数据作为一个发送分组,传送给它的数据链路层并封装成桢,然后以点对点的方式发送到目的主机。四、课程设计分析1. 课程设计中的重点及难点1) 程序中会用到Winpcap,Winpcap是Win32环境下数据包捕获的开放代码函数库。基于Winpcap的应用程序一般按照下面几个步骤进行设计:l 输出网卡设备列表。l 选择网卡并打开。l 捕获数据包时,可能需要设置过滤器。l 捕获数据包或者发送数据包。2) 在程序设计过程中需要注意网络主机字节顺序的转化。由于不同的计算机系统所采用的数据表示方式不同,对于2B或4B的数据,有的采用低字节地址存放数据的高权值位,而有的却以低地址字节存放数据低权位值,在网络的数据传输中,我们应该统一表示,所以我们在捕获数据包后,应将数据包头部的表示长度或类型的数据转换成本地机的表达形式。可以利用函数ntohs()将网络字节序转换为主机字节序。3) 选择网卡并打开时,注意选择可用的网卡。2. 参考算法1) 取得当前网卡设备列表。2) 选择Ethernet网卡并打开,注意判断所选网卡是否为实际存在的可用网卡。3) 设置过滤器,此处的过滤器正则表达式为“arp”或者“ether protoarp”。4) 捕获数据包并进行处理(包括输出各IP地址,物理地址,操作类型以及时间)。由于要记录日志文件,为了便于输出流参数,建议采用pcap_next_ex()函数。流程图如图所示:开始获取网卡列表选取Ethernet网卡打开网卡(混杂模式)编译设置过滤器捕获ARP包并将其相应内容输出3. 核心代码l ARP数据包结构struct arppkt unsigned short hdtyp; /硬件类型。值0001表示其为Ethernetunsigned short protyp; /协议类型。值0800表示上层协议为IPunsigned char hdsize; /硬件地址长度。值为06unsigned char prosize; /协议地址长度。值为04unsigned short op; /操作值为0001/0002,分别表示ARP请求/应答u_char smac6; /源MAC地址,6Bu_char sip4; /源IP地址,4Bu_char dmac6; /目的MAC地址u_char dip4; /目的IP地址;l 获取网络设备列表,并以混杂模式打开网络设备/获取网络设备列表if(pcap_findalldevs(&alldevs,errbuf)=-1)coutError in pcap_findalldevs:next) /以混杂模式打开网卡,以接受所有的帧if(adhandle=pcap_open_live(d-name,1000,1,300,errbuf)=NULL)coutaddresses!=NULL)break;l 编译过滤器并设置过滤器,只捕获ARP数据包char packet_filter=”ether proto ”; /过滤,选择arp协议if(pcap_compile(adhandle,&fcode,packet_filter,1,netmask)0) coutnUnable to compile the packet filter.Check the syntax.n; pcap_freealldevs(alldevs); return;/设置过滤器if(pcap_setfilter(adhandle,&fcode)0) cout=0) 输出ARP数据包的各个域的内容到文件和屏幕上 l 源程序#include#pragma comment(lib,Ws2_32.lib) /用到ntobs()/等同于点击project-setting-link打开object/library module编辑框后加入文件#pragma comment(lib,wpcap.lib)#include pcap.h /此头文件没有包含在VC中,需要另外加入#include#include /格式化输出需要用到#include /用到_getch() /注意到接收的数据包头中代表类型,数据长度的字段采用的是big-endian /所以对于2B/4B的数据要用ntohs()转换为本机形式 /ARP包结构struct arppktunsigned short hdtyp; /硬件类型.值0001unsigned short protyp;unsigned char hdsize;unsigned char prosize;unsigned short op;u_char smac6;u_char sip4;u_char dmac6;u_char dip4;void packet_handler(const pcap_pkthdr *header,const u_char *pkt_data,ostream& out);void main(int argc,char *argv )if(argc!=2)coutUsage:arpparse logfilenameendl;coutpress any key to continue.endl;_getch();return;pcap_if_t *alldevs;pcap_if_t *d;pcap_t *adhandle;char errbufPCAP_ERRBUF_SIZE;u_int netmask;char packet_filter=ether proto arp;struct bpf_program fcode;struct pcap_pkthdr *header;const u_char *pkt_data;if(pcap_findalldevs(&alldevs,errbuf)=-1)coutError in pcap_findalldevs:next) if(adhandle=pcap_open_live(d-name,1000,1,300,errbuf)=NULL)coutaddressess!=NULL)break;if(d=NULL) coutnetmask)-sin_addr.s_un.s_addr;/编译过滤器,只捕获ARP包if(pcap_compile(adhandle,&fcode,packet_filter,1,netmask)0) coutnUnable to compile the packet filter.Check the syntax.n; pcap_freealldevs(alldevs); return;/设置过滤器if(pcap_setfilter(ashandle,&fcode)0) coutnError setting the filter.n; pcap_freealldevs(alldevs); return;coutttlistening on description.endlendl;/显示提示信息及每项含义ofstream fout(argv1,ios:app); /日志记录文件/为了查看日志时的方便,其中加入了日期记录time_t t;time(&t);fout.seekp(0,ios:end);if(fout.tellp()!=0) foutendl;foutttARP request(1)/reply(2) onctime(&t);coutSour Ip Addr Sour MAC Address Des Ip Addr Des MAC Address OP Timeendl;foutSour Ip Addr Sour MAC Address Des Ip Addr Des MAC Address OP Time=0) if(result=0) continue; packer_handler(header,pkt_data,cout); packet_handler(header,pkt_data,fout);void packet_handler(const pcap_pkthdr *header,const u_char *pkt_data,ostream& out) arpkt* arph = (arppkt *)(pkt_data +14); for(int i=0;i3;i+) outsipi).; out.setf(ios:left); outsetw(3)sip3) ; out.unsetf(ios:uppercase); for(i=0;i5;i+) outhexsetw(2)smaci)-; outhexsetw(2)smac5) ; out.fill(oldfillchar); out.unsetf(ios:hex|ios:uppercase); for(i=0;i3;i+) outdip3).;out.unsetf(ios:left);/输出目的MAC地址out.fill(0);out.setf(ios:uppercase);for(i=0;i5;i+) outhexsetw(2)dmaci)-;out.fill(oldfillchar);out.unsetf(ios:hex|ios:uppercase);outop)ts.tv_sec);out.fill(0);outtm_hour:setw(2)tm_min:setw(2)tm_sec;out.fill(oldfillchar);outether_type)=0x0806) &(ntohs(arp_header-ar_hrd)=0x0001) &(ntohs(arp_header-ar_pro)=0x0800) &(arp_header-ar_hln=0x06)&(arp_header-ar_pln=0x04)&( (ntohs(arp_header-ar_op)=0x01)| (ntohs(arp_header-ar_op)=0x02) 对ARP数据包进行分析并打印5) 算法在3、4步之间进行循环,直到强行退出为止。六、心得体会本次课程设计,完成了在xp环境下的解析ARP数据包。在具体实现获取网络中的ARP数据包解析数据包的内容,并将其写入日志文件的过程中,是我更加清楚物理地址、IP地址的关联,源地址与目的地址的关系,以及二者对数据类型的格式要求。最重要的是通过这次的实际训练让我对ARP协议更加理解。本次课程设计查阅了大量的案例,学到了很多知识,使我对计算机网络有了更深入的了解。我觉得这次课程设计我觉得收获挺大的。之前的学习仅限于书本,网络的很多东西都只知道其然而不知道其所以然。课程设计是培养我们综合运用所学知识,发现、提出、分析和解决实际问题,锻炼实践能力的重要环节,是对我们实际工作能力的具体训练和考察过程。随着科学技术发展的日新月异,网络已经成为当今计算机发展中空前活跃的领域,在生活中可以说是无处不在,因此作为二十一世纪的计算机专业的大学生来说掌握网络组网技术是十分重要的。七、参考资料1. 谢希人著. 计算机网络(第四版)大连理工大学出版社20032. 宋凯等著. 计算机网络. 北京:清华大学出版社 20103. 吴功宜等著. 计算机网络课程设计. 北京:机械工业出版社2005.94. 李爱华等著. 面向对象程序设计(C+语言). 北京:清华大学出版社2010专心-专注-专业
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 办公文档 > 教学培训


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!