【C语言踩坑】PCAP发送ARP包之 --多出的字节

2024-04-16 14:18

本文主要是介绍【C语言踩坑】PCAP发送ARP包之 --多出的字节,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PCAP发送ARP包之多出的字节

-------------------------------------------------------------------------------------------------------------------
最近接触了一些计算机网络的底层协议,试着做了一个发送和接收ARP报文的demo,刚开始没注意,后来使用wireshark抓包才发现,发送出去的arp包全是无效的,难怪局域网中没有主机响应。我百度了数篇讲解ARP发包的博客,没有一个发现这个问题的,有的甚至就是直接复制的别人的源码。
-------------------------------------------------------------------------------------------------------------------
问题出现的根源在于cpu的内存优化策略,关于内存优化的详细解释你们可以看一下这篇博客https://blog.csdn.net/cyousui/article/details/17655051?utm_source=blogxgwz2
-------------------------------------------------------------------------------------------------------------------
构造的ARP包结构如图

arp报文结构

图中标明了初始化的数据
按理说发送的数据应该能被解析为一个arp广播请求,但是实际就是如下图的状况

arp-detect-error

arp-error-detail

很明显,报文无法被解析,但是能被判定为是一个arp报文,图中也可以清楚看出,目的mac地址和源mac地址以及协议类型都能被正确识别,但是值本应该是0001的arp操作类型字段却变成了0000,。是初始化出错了吗?仔细看这段报文的十六进制编码,你会发现,在08 06 00 00后面就有00 01的编码,而且后面的编码和初始化的数据一致,只是在本地mac地址编码后面又多出了两个00 00,从这里可以得出结论:00 00这个编码是被强行加进来的,并不是读取错误导致的。
但是这两字节的数据时怎么被加进去的呢?看下面这张程序运行时的内存值图你就清楚了。

detec-memory-error

这是我在arp包刚初始化结束的断点查看到的内存分布图,这说明,我在初始化后数据就已经被加了两字节的00数据。而罪魁祸首就是内存对齐和补齐策略,因为我是创建的32位程序,所以默认的是4bit补齐。因为arp包中的第三个字段结束后才14bit,所以系统就自动加了2bit的数据补齐16bit,使之变成4的整数倍。
既然问题找到了,那解决办法就好找了。

直接在代码的开头声明 按照1bit对齐就能解决这个问题。

#pragma pack(push) // 保持对齐方式
#pragma pack(1) // 设定1位对齐
-------------------------------------------------------------------------------------------------------------------
设置以后的内存分布图是这样的

arp-memory-success

没有多余的数据了
-------------------------------------------------------------------------------------------------------------------
wireshark抓取的arp正确报文是这样的

wireshark-success

实践出真知,国内就是喜欢抄袭,你好歹把错误改正下吧,真的是害人。我查这个错误查了一天。。。。

这篇关于【C语言踩坑】PCAP发送ARP包之 --多出的字节的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/909028

相关文章

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

C语言实现两个变量值交换的三种方式

《C语言实现两个变量值交换的三种方式》两个变量值的交换是编程中最常见的问题之一,以下将介绍三种变量的交换方式,其中第一种方式是最常用也是最实用的,后两种方式一般只在特殊限制下使用,需要的朋友可以参考下... 目录1.使用临时变量(推荐)2.相加和相减的方式(值较大时可能丢失数据)3.按位异或运算1.使用临时

使用C语言实现交换整数的奇数位和偶数位

《使用C语言实现交换整数的奇数位和偶数位》在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作,当我们谈论二进制位的奇数位和偶数位时,我们是指从右到左数的位置,本文给大家介绍了使... 目录一、问题描述二、解决思路三、函数实现四、宏实现五、总结一、问题描述使用C语言代码实现:将一个整

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st

Go语言中最便捷的http请求包resty的使用详解

《Go语言中最便捷的http请求包resty的使用详解》go语言虽然自身就有net/http包,但是说实话用起来没那么好用,resty包是go语言中一个非常受欢迎的http请求处理包,下面我们一起来学... 目录安装一、一个简单的get二、带查询参数三、设置请求头、body四、设置表单数据五、处理响应六、超

如何使用C#串口通讯实现数据的发送和接收

《如何使用C#串口通讯实现数据的发送和接收》本文详细介绍了如何使用C#实现基于串口通讯的数据发送和接收,通过SerialPort类,我们可以轻松实现串口通讯,并结合事件机制实现数据的传递和处理,感兴趣... 目录1. 概述2. 关键技术点2.1 SerialPort类2.2 异步接收数据2.3 数据解析2.

C语言中的浮点数存储详解

《C语言中的浮点数存储详解》:本文主要介绍C语言中的浮点数存储详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、首先明确一个概念2、接下来,讲解C语言中浮点型数存储的规则2.1、可以将上述公式分为两部分来看2.2、问:十进制小数0.5该如何存储?2.3 浮点