计算机网络——ARP协议、IP地址分类、VLSM

ARP协议 (地址解析协议)

广播 --- 交换机泛洪

广播地址 --- 全F

广播域 == 泛洪范围

ARP协议作用:

通过一种地址获取另外一种地址。

ARP的工作原理:ARP发送广播请求包,所有收到广播包的设备都需要先将数据包中的源IP和源MAC的映射关系记录在本地的ARP缓存表中,之后,再看请求的IP地址,如果请求的IP地址不是本地的IP地址,则直接丢弃;如果请求的IP地址是本地的IP地址,则将以单播的形式进行ARP应答。之后,再发送信息时,优先查看本地的ARP缓存表,如果有记录,则直接按照记录进行发送,否则,再发送ARP 请求,获取对方的MAC地址。

PC>arp -a --- 查看本地ARP缓存表

ARP缓存表老化时间 --- 180S

ARP欺骗是黑客的攻击方式之一,用于窃取信息,攻击者通过发送虚假的arp以欺骗主机,来获取数据包,过程可以称为代理arp

ARP的分类

正向ARP(AARP) --- 通过对端IP地址获取对端MAC地址

反向ARP (RARP)--- 通过本端mac地址来获取对端ip地址

免费(无故)ARP --- 1,自我介绍;2,检测地址冲

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ARP表项老化是指在一定时间内没有通信时,ARP表中的条目将被删除。这是为了防止ARP缓存表中的旧数据影响网络性能而采取的一种措施。以下是ARP表项老化的源码示例: ```c #define ARP_TIMEOUT 300 // ARP表项超时时间,单位为秒 struct arp_entry { uint32_t ip; uint8_t mac[6]; time_t timestamp; // 最后一次更新的时间戳 }; struct arp_entry arp_table[ARP_MAX_ENTRIES]; int arp_entry_count = 0; void arp_add_entry(uint32_t ip, uint8_t *mac) { // 添加ARP表项 if (arp_entry_count < ARP_MAX_ENTRIES) { arp_table[arp_entry_count].ip = ip; memcpy(arp_table[arp_entry_count].mac, mac, 6); arp_table[arp_entry_count].timestamp = time(NULL); arp_entry_count++; } } void arp_delete_entry(int index) { // 删除ARP表项 if (index >= 0 && index < arp_entry_count) { arp_entry_count--; for (int i = index; i < arp_entry_count; i++) { arp_table[i] = arp_table[i+1]; } } } void arp_update_entries() { // 更新ARP表项 time_t now = time(NULL); for (int i = 0; i < arp_entry_count; i++) { if (now - arp_table[i].timestamp > ARP_TIMEOUT) { arp_delete_entry(i); i--; // 因为删除了一个元素,需要重新检查当前位置 } } } ``` 在上述代码中,我们定义了一个结构体`arp_entry`来存储ARP表项的IP地址、MAC地址和时间戳。我们还定义了一个`arp_table`数组来存储所有ARP表项,以及一个`arp_entry_count`变量来记录当前ARP表中的条目数。 `arp_add_entry()`函数用于添加ARP表项,它将IP地址、MAC地址和时间戳保存到`arp_table`数组中。如果`arp_entry_count`已经达到了最大值`ARP_MAX_ENTRIES`,则无法添加新的ARP表项。 `arp_delete_entry()`函数用于删除ARP表项,它将指定位置的ARP表项删除,并将后面的所有ARP表项向前移动一个位置。 `arp_update_entries()`函数用于更新ARP表项,它遍历所有ARP表项,检查它们是否已经超时。如果一个ARP表项的时间戳与当前时间的差值大于`ARP_TIMEOUT`,则将其删除。 通过这些函数,我们可以实现ARP表项的添加、删除和更新。在使用ARP协议时,我们应该定期调用`arp_update_entries()`函数来清理过期的ARP表项,以提高网络性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值