ARP(地址解析协议)
地址解析协议,即ARP,是根据IP地址获取物理地址的一个TCP/IP协议。主机发送信息时,将目标IP地址的ARP请求广播到局域网上的所有主机,并接受返回消息,以此确定目标的物理地址;收到返回消息后,将该IP地址和物理地址存入本机ARP缓存中并保留一定时间,下次请求时直接查询ARP缓存以节约资源。地址解析协议是建立在网络中各个主机互相信任的基础上的,局域网络上的主机可以自主发送ARP应答消息,其他主机收到应答报文时不会检测报文的真实性就会将其计入本机ARP缓存;由次攻击者就可以向某一主机发送伪ARP应答报文,使其发送的信息无法到达预期的主机或到达错误的主机,这就构成了一个ARP欺骗。ARP命令可用工与查询本机ARP缓存中IP地址和MAC地址的对应关系、添加或删除静态对应关系等。相关协议有RARP ,代理ARP。NDP用于在IPV6中代替地址解析协议。
ARP的工作过程:
主机A的IP地址为192.168.1.1,MAC地址为0A-11-22-33-44-01;
主机B的IP地址为192.168.1.2,MAC地址为0A-11-22-33-44-02;
当主机A与主机B通信时,地址解析协议可以将主机B的IP地址解析成主机B的MAC地址,一下为工作流程:
- 根据主机A上的路由表的内容,IP确定用于访问主机B的转发IP地址192.168.1.2.然后A主机在自己的本地ARP缓存中检查主机B的MAC地址。
- 如果主机A在ARP缓存中没有找到映射,它将询问192.168.1.2的硬件地址,从而将请求帧关闭到本地网络上的所有主机,源主机A的IP地址和MAC地址都包括在ARP请求中。本地网络上的每台主机都接收到ARP请求并检查是否与自己的IP地址相匹配,如果主机发现请求的IP地址域自己的IP地址不匹配,它将丢弃ARP请求
- 主机B确定ARP请求中的IP地址与自己的IP地址匹配,则将主机A的IP地址和MAC地址映射添加到本地ARP缓存中。
- 主机B将包含其MAC地址的ARP应答消息支架发送回主机A
- 当主机A收到从主机B发出来的ARP恢复消息时,会用主机B的IP和MAC地址映射更新ARP缓存。本机缓存是有生存期的,生存期结束够,将再次重复上面的过程。主机B的MAC地址一旦确定,主机A就能向主机B发送IP通信了。
工作要素:
ARP缓存:是一个用来存储IP地址和MAC地址的缓冲区,其本质就是一个IP地址—>MAC地址的对应表,表中每一个条目分别记录了网络上其他主机的IP地址和对应的MAC地址。每一女王以太网或令牌环网适配器都有自己单独的表。当地址解析协议被询问一个已知IP地址结点的MAC地址时,先在ARP缓存中查看,若存在,就直接返回与之对应的MAC地址,若不存在,才发送ARP请求相局域网查询。
为使广播量最小,ARP维护IP地址到MAC地址映射的缓存以便将来使用。ARP缓存可以包含动态和静态项目。动态项目随时间推动自动添加和删除。每个动态ARP缓存项的潜在生命周期是10分钟,新加到缓存中的项目带有时间戳,如果某个项目添加后2分钟内没有再使用,则此项目过期并从ARP缓存中删除;如果某个项目已在使用,则又收到2分钟的生命周期里如果某个项目始终在使用,则会另外收到2分钟的生命周期致到10分钟的最长的生命周期。静态项目一直保留在缓存中,直到重新启动计算机为止。
ARP欺骗
地址解析协议是建立在网络中各个主机互相信任的基础上的,它的诞生使得网络能够更加高效的运行,但其本身也存在缺陷:
ARP地址转换表是以利于计算机中告诉缓冲存储器动态更新的,而高速缓冲存储器更新是收到更新周期的限制的,只保存最近使用的地址的映射关系表项,这时的攻击者有了。