2.1 - 网络协议 - ARP协议原理,报文解析,抓包实战

「作者主页」:士别三日wyx
「作者简介」:CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者
「推荐专栏」:对网络安全感兴趣的小伙伴可以关注专栏《网络安全入门到精通》

ARP协议

ARP(Address Resolution Protocol)是 「地址解析协议」,可以根据IP地址获取Mac地址。

「Mac地址」是计算机的「唯一标识」,数据从网络层传输到链路层时,只知道IP地址,但不知道Mac地址,因此需要使用ARP协议将IP地址解析成Mac地址,才能通信。

1、ARP协议原理

ARP协议规定:每台计算机和路由器都维护一个「ARP缓存表」,用来保存IP和Mac地址的映射关系。

arp -a可以查看ARP地址缓存表

通信的时候,计算机就根据目的IP判断是不是「同网段IP」,如果是同网段,就在当前局域网内查询。

  1. 先查自己的「ARP缓存表」,如果有,就直接跟Mac地址对应的计算机通信。
  2. 如果没有,就发「ARP广播」,报文里携带目的IP地址,局域网内的所有主机都会收到广播。
  3. 收到广播的主机会看目的IP是不是自己,如果不是,就什么也不做。
  4. 如果是,就响应一个「ARP单播」,把自己的Mac地址发回去。
  5. 计算机收到响应的单播,就跟报文里的Mac地址通信,然后把IP和Mac地址保存到自己的ARP缓存表里,下次就直接查表,不用广播了。

如果目的IP「不是同网段」,就通过路由器发给目标局域网的路由器。

  1. 路由器先查自己的ARP缓存表,如果有,就把Mac地址发回去。
  2. 如果没有,就广播,收到单播的Mac地址,保存到自己的ARP缓存表里,然后把Mac地址发回去。

2、ARP协议报文

  • Hardware type:硬件类型【2字节】
  • Protocol type:协议类型【2字节】
  • Hardware size:硬件地址长度【1字节】
  • Portocol size:协议长度【1字节】
  • Opcode:操作类型【2字节】request表示请求,reply表示响应
  • Sender Mac address:发送方Mac地址【6字节】
  • Sender IP address:发送方IP地址【4字节】
  • Target MAC address:目标Mac地址【6字节】
  • Target IP address:目标IP地址【4字节】

3、ARP协议抓包分析

1)cmd 获取局域网内所有主机,注意把第三位IP地址改成自己的网段

代码的意思是:ping 192.168.0.1192.168.0.255 之间的所有IP

powershell 复制代码
for /L %i IN (1,1,254) DO ping -w 2 -n 1 192.168.31.%i

2)arp -a 查看本网段的IP

3)记录一个本网段的IP,然后 arp -d 清空ARP表

4)Wireshark开启抓包后,ping 那个本网段的IP

5)显示过滤器中输入:arp,过滤ARP协议的数据包

  • 第一个包是ARP协议的广播请求包,我的电脑(7a:d3:8e:0e:32:4f)发送了一个广播(Broadcast)报文:"谁是192.168.31.118?告诉192.168.31.121(我的IP)"
  • 第二个包是ARP协议的单播响应包,有个电脑响应我: "192.168.31.11874:b5:87:db:06:ac"

第一个包的数据中,request表示这是ARP请求包,包里源、目的IP、源Mac都有值,但目的Mac没有值。意思是:我不知道这个IP的Mac地址。

第二个包的数据中,reply表示这是ARP响应包,包里源、目的IP,源、目的Mac都有值了。接收方可以从这里获取Mac地址。

4、ARP自主学习

1)arp -d 清空ARP表。

2)ping 前面记录的那个IP,模拟一次ARP寻址。

3)arp -a 查看ARP表,可以看到那个IP被缓存了。

4)Wireshark开启抓包,再ping一次那个IP。

查看ARP请求包的目的MAC地址,不再是空的了。因为这是第二次访问,ARP缓存表李有记录了,就不再广播了。

相关推荐
AI机器学习算法2 小时前
深度学习模型演进:6个里程碑式CNN架构
人工智能·深度学习·cnn·大模型·ai学习路线
Ztopcloud极拓云视角2 小时前
从 OpenRouter 数据看中美 AI 调用量反转:统计口径、模型路由与多云应对方案
人工智能·阿里云·大模型·token·中美ai
AI医影跨模态组学2 小时前
如何将深度学习MTSR与膀胱癌ITGB8/TGF-β/WNT机制建立关联,并进一步解释其与患者预后及肿瘤侵袭、免疫抑制的生物学联系
人工智能·深度学习·论文·医学影像
大鹏说大话2 小时前
SSL证书自动化的未来:ACME协议与Let’s Encrypt实践
网络·安全
搬砖的前端3 小时前
AI编辑器开源主模型搭配本地模型辅助对标GPT5.2/GPT5.4/Claude4.6(前端开发专属)
人工智能·开源·claude·mcp·trae·qwen3.6·ops4.6
被摘下的星星3 小时前
网际协议(IP协议)
网络·tcp/ip
Python私教3 小时前
Hermes Agent 安全加固与生态扩展:2026-04-23 更新解析
人工智能
饼干哥哥3 小时前
Kimi K2.6 干成了Claude Design国产版,一句话生成电影级的动态品牌网站
人工智能
肖有米XTKF86464 小时前
带货者精品优选模式系统的平台解析
人工智能·信息可视化·团队开发·csdn开发云
天天进步20154 小时前
打破沙盒限制:OpenWork 如何通过权限模型实现安全的系统级调用?
人工智能·安全