你的位置:pcMing工作室 >> 资讯 >> 网络技术 >> 详细内容 在线投稿

ARP协议的解码详解

排行榜 收藏 打印 发给朋友 举报 来源: 互联网   发布者:未知
热度122票  浏览6次 【共0条评论】【我要评论 时间:2010年2月12日 20:03

一、ARP协议简介

,T+h^H V6eI;Y0ARP,全称Address Resolution Protocol,中文名为地址解析协议,它工作在数据链路层,在本层和硬件接口联系,同时对上层提供服务。pcMing工作室IRM] E5C

pcMing工作室#Z,\"P_5?"@s$S

IP数据包常通过以太网发送,以太网设备并不识别32位IP地址,它们是以48位以太网地址传输以太网数据包。因此,必须把IP目的地址转换成以太网目的地址。在以太网中,一个主机要和另一个主机进行直接通信,必须要知道目标主机的MAC地址。但这个目标MAC地址是如何获得的呢?它就是通过地址解析协议获得的。ARP协议用于将网络中的IP地址解析为的硬件地址(MAC地址),以保证通信的顺利进行。pcMing工作室 [e7O ST D!@C

pcMing工作室e sGmW`"`1w#n7M

1.  ARP和RARP报头结构

YT(o1^.N$|-\eZt0

W-R/Llr0ARP和RARP使用相同的报头结构,如图1所示。

p,E?'Q'|0X w0

 pcMing工作室(e2?;Y:P;|

(图1 ARP/RARP报头结构)pcMing工作室Pc.{ K r9c_9\

xf$J uCNN(I0硬件类型字段:指明了发送方想知道的硬件接口类型,以太网的值为1;pcMing工作室.wbP;\7M,q(].^

L7^I M\2h0协议类型字段:指明了发送方提供的高层协议类型,IP为0800(16进制);
P_V+ZQ"n9VO5G0
oCAc^2Y*^pB#p0硬件地址长度和协议长度:指明了硬件地址和高层协议地址的长度,这样ARP报文就可以在任意硬件和任意协议的网络中使用;pcMing工作室dW3oz:VL&yKi%@

g-SK-I&w-K0操作字段:用来表示这个报文的类型,ARP请求为1,ARP响应为2,RARP请求为3,RARP响应为4;

:|0`*BOE/a*I(X0

1V*ssyE2[M/x'W0发送方的硬件地址(0-3字节):源主机硬件地址的前3个字节;

*f:}(fH!N7F!@0

vq^@~D0发送方的硬件地址(4-5字节):源主机硬件地址的后3个字节;

5t-zpq/FBU9I)t0pcMing工作室 C+Ez"[1E1aG};ii

发送方IP(0-1字节):源主机硬件地址的前2个字节;pcMing工作室L$d)w0N'{Bwy[

pcMing工作室%L/Cz[[-X m"F lU

发送方IP(2-3字节):源主机硬件地址的后2个字节;

d Q%@ pdeB#c k\d0

`8{A"b,{q-M8Y0|0目的硬件地址(0-1字节):目的主机硬件地址的前2个字节;

$h(G*E:P5Wc7V {0

c `glI(TI0目的硬件地址(2-5字节):目的主机硬件地址的后4个字节;pcMing工作室}8I pj']

|O,e3R y{0目的IP(0-3字节):目的主机的IP地址。pcMing工作室 y2IyOIL"o+p

pcMing工作室_im7us

2.  ARP和RARP的工作原理

ell0e6[}-Qr)Hw0pcMing工作室;C}:}F$gD]si;vslJ

ARP的工作原理如下:pcMing工作室"mmm%D'~L

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

Pa6{1W/~Q c^4{0pcMing工作室2X+[9{+v@TZ

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

pcMing工作室#Zb A&n ^(}2J!cf

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

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

+c$~*|L}{b0

Lp6Qg{A8g_d0RARP的工作原理:pcMing工作室5A6F['wcHS v#ue

i0~!k,]Z!L2~ tz#H01.  发送主机发送一个本地的RARP广播,在此广播包中,声明自己的MAC地址并且请求任何收到此请求的RARP服务器分配一个IP地址;pcMing工作室9AKj6F4t}$M!|-C:L8~

/V2S-VeB4_-s@W02. 本地网段上的RARP服务器收到此请求后,检查其RARP列表,查找该MAC地址对应的IP地址;

db[%rd6SS0pcMing工作室'w8]/q ^af6U0}Z

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

h n:TN-mF0L0

)^ |i Q&S`"~r5t04. 如果不存在,RARP服务器对此不做任何的响应;pcMing工作室MFv3|,I T` U#f

$TmWX)zT&gF H05. 源主机收到从RARP服务器的响应信息,就利用得到的IP地址进行通讯;如果一直没有收到RARP服务器的响应信息,表示初始化失败。pcMing工作室j5hy^^9~)U?5@

@6@/o%cI D*wh squ&n0二、解码详解pcMing工作室7Zr s4d4b9Y

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

.g{&x0_g0

 

t5rld7X6j)F0

(图2 科来网络分析系统中ARP请求包详细解码)pcMing工作室 Bhcl+k8y"m
pcMing工作室s R{#\,}B K%G1b/`m

1HC-Y l$eHq0

$^EBM*C)U0图2显示是一个ARP的请求包的解码,下面我们来详细说明:pcMing工作室6M g#C0^?

pcMing工作室s5pi1r(I6Y-\.p}/|

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

+f i8r5h B%CfO [6^7l0pcMing工作室&[2a];ysha Q-a

协议类型:0x0800,表示发送方提供的高层协议类型是IPpcMing工作室wEX#o,[0@%gp

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

,H@g%R4~ l/@e0

9[Nl$v2| yD0协议地址长度:表示IP地址长度为4字节=32位pcMing工作室hU0E*tyD L4[l

'^7ZjX-M?P{9F/c_0操作类型:1,表示ARP请求pcMing工作室YM`@.h7b

'E4z!~S#f,C/G-gPN0源物理地址:00:14:85:CA:F5:22pcMing工作室%~#~!G`B"L E|pV

pcMing工作室oA;Ld*|BV

源IP地址:192.168.0.92pcMing工作室}-r,Qc2R|H

5rO]6N6\0目标物理地址:00:00:00:00:00:00pcMing工作室e5X3} cd9R

pcMing工作室`,D{Z0Jc8\

目标IP地址:192.168.0.208

)QSizB"\'F0pcMing工作室ja&}b9Y^go

ARP回应包和RARP的包类似,我们在这里就不再重复说明。pcMing工作室;e8x:iV#K%DW

TAG: ARP
顶:5 踩:5
对本文中的事件或人物打分:
当前平均分:-0.16 (38次打分)
对本篇资讯内容的质量打分:
当前平均分:0.9 (39次打分)
【已经有35人表态】
5票
感动
5票
路过
4票
高兴
3票
难过
5票
搞笑
5票
愤怒
5票
无聊
3票
同情
上一篇 下一篇
发表评论
换一张

网友评论仅供网友表达个人看法,并不表明本网同意其观点或证实其描述。

查看全部回复【已有0位网友发表了看法】

网络资源