计算机网络课程设计实验报告Word文件下载.doc
《计算机网络课程设计实验报告Word文件下载.doc》由会员分享,可在线阅读,更多相关《计算机网络课程设计实验报告Word文件下载.doc(35页珍藏版)》请在冰豆网上搜索。
实验内容:
Ping命令实现的扩充,在给定的Ping程序的基础上做如下功能扩充:
-h 显示帮助信息
-b 允许ping一个广播地址,只用于IPv4
-t设置ttl值,只用于IPv4
-q 安静模式。
不显示每个收到的包的分析结果,只在结束时,显示汇总结果
Ping命令的基本描述
Ping的操作是向某些IP地址发送一个ICMPEcho消息,接着该节点返回一个ICMPEchoreplay消息。
ICMP消息使用IP头作为基本控制。
二、实验环境
实验一数据包的捕获与分析
1.联网计算机
2.Windows或linux系统
3.在PC中安装协议分析软件(如:
Wireshark)
4.物理基础:
IEEE802.3标准的以太网采用的是持续CSMA的方式,正是由于以太网采用这种广播信道争用的方式,使得各个站点可以获得其他站点发送的数据。
运用这一原理使信息捕获系统能够拦截的我们所要的信
5.工作模式:
1)广播模式(BroadCastModel):
它的物理地址(MAC)地址是0Xffffff的帧为广播帧,工作在广播模式的网卡接收广播帧。
2)多播传送(MultiCastModel):
多播传送地址作为目的物理地址的帧可以被组内的其它主机同时接收,而组外主机却接收不到。
但是,如果将网卡设置为多播传送模式,它可以接收所有的多播传送帧,而不论它是不是组内成员。
3)直接模式(DirectModel):
工作在直接模式下的网卡只接收目地址是自己MAC地址的帧。
4)混杂模式(PromiscuousModel):
工作在混杂模式下的网卡接收所有的流过网卡的帧,信包捕获程序就是在这种模式下运行的。
实验二网络层实验—Ping程序的设计与实现
1.联网计算机
2.Linux系统
3.系统自带编译环境
三、程序的需求分析与逻辑框图
需求分析
1、实验一
数据包的捕获与分析
1>
.在PC中安装协议分析软件。
2>
.启动Wireshark协议分析软件,选择抓包菜单项启动实时监视器,开始实时跟踪显示网络数据报文。
可根据系统提示修改显示方式。
3>
.调出跟踪存储的历史报文,选择有代表性的ETHERNET,IEEE802.3,IP,ICMP,TCP,UDP报文,对照有关协议逐个分析报文各字段的含义及内容。
4>
.设置过滤器属性,如目的地址,源地址,协议类型等。
如过滤不需要的网络报文,过滤器允许设置第二层,第三层或第四层的协议字段。
2、实验二
网络层实验—Ping程序的设计与实现
PING程序是我们使用的比较多的用于测试网络连通性的程序。
PING程序给予ICMP使用ICMP的回送请求和回送应答来工作。
ICMP是基于IP的一个协议,ICMP包通过IP的封装之后传递。
实现检测网络通畅及速度的ping,并扩展以下功能:
-h显示帮助信息
-b允许ping一个广播地址,只用于IPv4
-t设置ttl值,只用于IPv4
-q安静模式,不显示每个收到的包的分析结果,只在结束时,显示汇总结果
三、程序的需求分析与逻辑框图
逻辑框图
1、总体设计
程序分为两大部分:
一部分读取收到的所有消息,并输出ICMPEchoreplay消息,另一部分每个一秒钟发送一个Echo消息。
另一部分由SIGALARM信号每秒驱动一次。
2、详细设计
1)main函数
三、 程序的需求分析与逻辑框图
2)readloop函数
3)proc函数 4)send函数
Checksum开始
定义初始化cksum
(size>
1)
确定cksum及size大小
是
if(size)
计算校验cksum,获得结果
cksum+=*(UCHAR*)buffer;
否
结束
四、程序核心功能的实现机制
利用协议分析软件跟踪局域网报文,实验内容如下:
将安装协议分析软件的PC接入以太网中,跟踪PC之间的报文,并存入文件以备重新查。
设置过滤器过滤网络报文以检测特定数据流。
利用协议分析软件的统计工具显示网络报文的各种统计信息。
IP头的格式如下
0123
01234567890123456789012345678901
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|Version|IHL|TypeofService|TotalLength|
|Identification|Flags|FragmentOffset|
|TimetoLive|Protocol|HeaderChecksum|
|SourceAddress|
|DestinationAddress|
Version=4
IHLInternet头长
TypeofService=0
TotalLengthIP包的总长度
Identification,Flags,FragmentOffset用于IP包分段
TimetoLiveIP包的存活时长
ProtocolICMP=1
Addresses发送Echo消息的源地址是发送Echoreply消息的目的地址,相反,发送Echo消息的目的地址是发送Echoreply消息的源地址。
四、程序核心功能的实现机制
Ping实际上是使用ICMP中的ECHO报文来实现的。
Echo或EchoReply消息格式如下:
0123
01234567890123456789012345678901
|Type|Code|Checksum|
|Identifier|SequenceNumber|
|Data...
+-+-+-+-+-
Type
echo消息的类型为8
echoreply的消息类型为0。
Code=0
Checksum
为从TYPE开始到IP包结束的校验和
Identifier
如果code=0,identifier用来匹配echo和echoreply消息
SequenceNumber
功能描述:
收到echo消息必须回应echoreply消息。
identifier和sequencenumber可能被发送echo的主机用来匹配返回的
echoreply消息。
例如:
identifier可能用于类似于TCP或UDP的port
用来标示一个会话,而sequencenumber会在每次发送echo请求后递增。
收到echo的主机或路由器返回同一个值与之匹配
四、 程序核心功能的实现机制
1、 数据结构的描述
1)IP包格式
structip{
BYTEVer_ihl;
//版本号与包头长度
BYTETOS;
//服务类型
WORDLeng;
//IP包长度
WORDId;
//IP包标示,用于辅助IP包的拆装,本实验不用,置零
WORDFlg_offset;
//偏移量,也是用于IP包的拆装,本实验不用,置零
BYTETTL;
//IP包的存活时间
BYTEProtocol;