Chinaunix首页 | 论坛 | 博客
  • 博客访问: 318022
  • 博文数量: 93
  • 博客积分: 2515
  • 博客等级: 少校
  • 技术积分: 1025
  • 用 户 组: 普通用户
  • 注册时间: 2007-09-18 22:51
文章分类

全部博文(93)

文章存档

2010年(2)

2009年(26)

2008年(65)

我的朋友

分类:

2009-01-07 16:21:03


ARP工作原理和ARP协议解码详解
 2.ARP和RARP的工作原理

  ARP的工作原理如下:

  1. 首先,每台主机都会在自己的ARP缓冲区 (ARP Cache)中建立一个 ARP列表,以表示IP地址和MAC地址的对应关系。

   2. 当源主机需要将一个数据包要发送到目的主机时,会首先检查自己 ARP列表中是否存在该 IP地址对应的MAC地址,如果有﹐就直接将数据包发送到这个MAC地址;如果没有,就向本地网段发起一个ARP请求的广播包,查询此目的主机对应的 MAC地址。此ARP请求数据包里包括源主机的IP地址、地址、以及目的主机的IP地址。

   3. 网络中所有的主机收到这个ARP请求后,会检查数据包中的目的IP是否和自己的IP地址一致。如果不相同就忽略此数据包;如果相同,该主机首先将发送端的 MAC地址和IP地址添加到自己的ARP列表中,如果ARP表中已经存在该IP的信息,则将其覆盖,然后给源主机发送一个 ARP响应数据包,告诉对方自己是它需要查找的MAC地址;

  4. 源主机收到这个ARP响应数据包后,将得到的目的主机的IP地址和MAC地址添加到自己的ARP列表中,并利用此信息开始数据的传输。如果源主机一直没有收到ARP响应数据包,表示ARP查询失败。

  RARP的工作原理:

  1. 发送主机发送一个本地的RARP广播,在此广播包中,声明自己的MAC地址并且请求任何收到此请求的RARP服务器分配一个IP地址;

  2. 本地网段上的RARP服务器收到此请求后,检查其RARP列表,查找该MAC地址对应的IP地址;

  3. 如果存在,RARP服务器就给源主机发送一个响应数据包并将此IP地址提供给对方主机使用;

  4. 如果不存在,RARP服务器对此不做任何的响应;
  
  5. 源主机收到从RARP服务器的响应信息,就利用得到的IP地址进行通讯;如果一直没有收到RARP服务器的响应信息,表示初始化失败。

  二、解码详解

  了解了ARP和RARP协议的报头结构和工作原理后,我们使用科来网络分析系统抓取ARP包,其详细解码,如图2,

  
 

  
  (图2 科来网络分析系统中ARP请求包详细解码)



  图2显示是一个ARP的请求包的解码,下面我们来详细说明:

  硬件类型:1,表示硬件借口类型为以太网类型

  协议类型:0x0800,表示发送方提供的高层协议类型是IP

  硬件地址长度:表示硬件地址长度为6字节=48位

  协议地址长度:表示IP地址长度为4字节=32位

  操作类型:1,表示ARP请求

  源物理地址:00:14:85:CA:F5:22

  源IP地址:192.168.0.92

  目标物理地址:00:00:00:00:00:00

  目标IP地址:192.168.0.208

  ARP回应包和RARP的包类似,我们在这里就不再重复说明。

阅读(1696) | 评论(0) | 转发(0) |
0

上一篇:08/12/26

下一篇:几个面试题与解答

给主人留下些什么吧!~~