拆包--缓冲区查找包头及包尾偏移

缓冲区查找包头及包尾偏移

  • 前言
  • 一、采用动态数组QByteArray的自带函数
  • 二、采用字节对比方法
  • 测试代码

前言

根据前面所讲的内容封包拆包,当将网络中的数据读出存储在自定义缓冲区QByteArray中,则对数据包进行拆分。则首先要进行的工作就是找到包头的位置及包尾的位置,来判断该包是否完整,下面就来讲两种方法来查找其偏移地址。

一、采用动态数组QByteArray的自带函数

该方法主要就是采用QByteArray的indexOf(const QByteArray &, int)函数,buf表示缓冲区数据,data表示比较包头或包尾的数据,Len表示包头包尾长度。

int Find1(const QByteArray &buf, const char * data, int Len)
{QByteArray array;array.append(data, Len);return buf.indexOf(array);
}

二、采用字节对比方法

该方法主要就是采用字节对比,buf表示缓冲区数据,data表示比较包头或包尾的数据,Len表示包头包尾长度。

int Find2(const QByteArray &buf, const char * data, int Len)
{if (buf.size() < Len){return -1;}const char *temp = buf.data();for (int i = 0; i < buf.size()-Len+1; i++){for (int j = 0; j <= Len; j++){if (j == Len){return i;}if (*(temp+i+j) != *(data+j)){break;}}}
}

测试代码

processor.h:

#pragma pack(1)
#define PACK_HEAD 0xf1f2
#define PACK_TAIL 0xf2f3typedef struct
{short dataHead;long long dataLen;
}HEAD;typedef struct
{short b;int c;long long d;
}DATA;typedef struct
{short daraTail;
}TAIL;#pragma pack()

main.cpp:


#include <QtCore/QCoreApplication>
#include <QtDebug>
#include <QFile>
#include "processor.h"int Find1(const QByteArray &buf, const char *, int Len);
int Find2(const QByteArray &buf, const char * data, int Len);int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);
///创建包结构(模拟接收到网络数据后的缓存区)HEAD head;TAIL tail;QFile file("test.dat");   //二进制文件file.open(QIODevice::ReadOnly);char buf[2*1024];qint64 readLen = file.read(buf,sizeof(buf));head.dataLen = 1400;        DATA *param = (DATA *)buf;head.dataHead = PACK_HEAD;tail.daraTail = PACK_TAIL;char *buf1 = new char[8*1024];memcpy(buf1,&head,sizeof(HEAD));memcpy(buf1+sizeof(HEAD),param,readLen);memcpy(buf1+sizeof(HEAD)+readLen,&tail,sizeof(TAIL));int len = sizeof(HEAD)+ readLen + sizeof(TAIL);QByteArray buffer;buffer.append(buf1, len);       //缓冲区数据file.close();
if (buffer.size() > sizeof(HEAD)){int headOffset = Find2(buffer, (char *)&head, sizeof(head.dataHead));int tailOffset = Find2(buffer,(char *)&tail, sizeof(tail.daraTail));if (tailOffset-headOffset == len-sizeof(tail.daraTail)){QByteArray headTest= buffer.mid(headOffset,sizeof(HEAD));   //头文件HEAD *packHead = (HEAD *)headTest.data();if (packHead->dataHead == head.dataHead){QByteArray dataTest = buffer.mid(headOffset+sizeof(HEAD),packHead->dataLen);DATA *packData = (DATA *)dataTest.data();qDebug()<<QString::fromLocal8Bit("数据获取成功");}}else{qDebug()<<QString::fromLocal8Bit("数据丢失");}}return a.exec();
}int Find1(const QByteArray &buf, const char * data, int Len)
{QByteArray array;array.append(data, Len);return buf.indexOf(array);
}int Find2(const QByteArray &buf, const char * data, int Len)
{if (buf.size() < Len){return -1;}const char *temp = buf.data();for (int i = 0; i < buf.size()-Len+1; i++){for (int j = 0; j <= Len; j++){if (j == Len){return i;}if (*(temp+i+j) != *(data+j)){break;}}}
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/427906.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

5自适应单页源码_超详细!如何建立一个CPA单页网站,附高转化CPA模板源码

做CPA的老手一般都会建立一个CPA单页站&#xff0c;用来提升转化&#xff0c;提高推广质量。今天教大家搭建一个完整的CPA单页站搭建一个网站需要3样东西&#xff1a;域名服务器网站源码一、购买域名域名就是你网站的地址&#xff0c;建议从万网购买就可以&#xff0c;比较方便…

20154319 《网络对抗技术》后门原理与实践

一、实验说明 任务一&#xff1a;使用netcat获取主机操作Shell&#xff0c;cron启动 (0.5分) 任务二&#xff1a;使用socat获取主机操作Shell, 任务计划启动 (0.5分) 任务三&#xff1a;使用MSF meterpreter&#xff08;或其他软件&#xff09;生成可执行文件&#xff0c;利用…

强制类型转换的取整及四舍五入取整

强制类型转换取整相关前言取整方法例&#xff1a;(signed int)double四舍五入取整前言 开发中一般运算过程都采用浮点类型数据以免出现运算不精确的错误&#xff0c;而当运算结果需要时整型的时候就需要对浮点类型的结果进行取整处理&#xff0c;而取整的方法有向上取整&#…

关于字节对齐

关于字节对齐前言意义自定义字节对齐存储空间内存读取效率平台适应性结论前言 计算机中的内存空间大小是以字节&#xff08;byte&#xff09;为基本单位划分的&#xff0c;从理论上讲似乎对任何类型的变量的访问可以从任何地址开始&#xff0c;而计算机并非逐字节大小读写内存…

c++中的多线程

使用 std::thread 时需要包含 #include<thread> 头文件&#xff0c;定义了表示线程的类、用于互斥访问的类与方法等。 参考网址&#xff1a; https://blog.csdn.net/liuker888/article/details/46848905https://blog.csdn.net/fengbingchun/article/details/73393229成员…

C++ reverse memcpy

C reverse memcpy前言基于QT的测试样例结果前言 C 实现翻转memcpy 基于QT的测试样例 代码如下&#xff1a; #include <iostream> #include <QtCore/QCoreApplication> #include <QDebug>using namespace std;void *reversememcpy(void *out, const void *…

打架程序_学生打架不知道怎么处理?一般程序了解下,对你或许有帮助

很多新老师&#xff0c;对处理学生问题的步骤其实还不是很了解&#xff0c;一遇到学生问题就很苦恼&#xff0c;用的方法很多&#xff1a;或劝、或骂、或赏、或罚&#xff0c;但总是觉得不得要领。今天我想通过昨天我处理的一个实例&#xff0c;针对性的聊一聊这个问题。希望对…

jsp中设置自动换行_办公技巧—Word中如何设置自动生成序号

我们经常会用到Word来编辑文档&#xff0c;经常需要在文档中插入各种序号。如果一个个手动输入这些序列号&#xff0c;会降低我们的工作效率。那么&#xff0c;这种情况下&#xff0c;我们该怎么办呢&#xff1f;今天&#xff0c;小编就教各位Word中设置自动生成序号的小技巧&a…

mongodb如何根据字段(数组类型)的长度排序_大数据存储技术选型(七)——MongoDB设计模式及索引优化...

关系数据库的时代关系数据库的设计理念假设你有一台车&#xff0c;你需要给它存起来&#xff0c;给它找个停车位。传统数据库的存储方式就相当于&#xff0c;把这个车的所有零件拆下来&#xff0c;放在存放对应零件的盒子里&#xff0c;需要用的时候&#xff0c;再把他们取出来…

幼小衔接语言教案上c册_关于幼小衔接,这里有你最想要的解答

相信很多家长都会发现&#xff0c;在孩子即将步入小学的前一年或者半年左右&#xff0c;身边同龄的孩子有一部分会放弃大班的学习&#xff0c;转而去幼小衔接班了。就算平时再佛系的妈妈&#xff0c;内心也会焦虑&#xff0c;产生疑问&#xff1a;到底要不要上幼小衔接班&#…

每日一题20180330-Linux

一、问题 1.1 统计/var/log/下所有文件个数 1.2 查找出/var/log目录下面修改时间是7天以前&#xff0c;大小在50k到2M之间&#xff0c;并以.log结尾的文件把这些文件复制到/data目录中 1.3 设置一条Iptables规则&#xff0c;允许192.168.10.0段访问873端口&#xff1f; 二、答案…

前台文件_欧木瑾怎么定制办公前台?

前台是一个反映公司整体形象的地方。这是给客户和商业伙伴留下印象的第一个地方。因此&#xff0c;芜湖绿木家具有限公司欧木瑾小编说公司的前台装修不能马虎。前台的设计风格与材料的使用有很大关系。从细节上看&#xff0c;这是材料的精美运用。这里是如何设计一个好的前台。…

单纯形法只有两个约束条件_10分钟掌握对偶单纯形法

只听名字的话会感觉对偶单纯形法和对偶问题关系很大&#xff0c;其实不然(想要了解对偶问题的话可以看我之前的文章)。对偶单纯形法在我看来和大M法以及两阶段法很像&#xff0c;都是用来补充纯粹的单纯形法无法解决特殊问题的缺陷。而且对偶单纯形法更加“强大”&#xff0c;因…

linix防火墙设置之顺序设置问题 -- 解决防火墙规则顺序和插入规则到指定序号的问题...

转载于百度经验&#xff1a;https://jingyan.baidu.com/article/ae97a646ce58c2bbfd461d90.html 无论是硬件防火墙还是软件防火墙都会有一个规则序列的问题&#xff0c;规则顺序会影响到规则的生效情况&#xff0c;所以这个必须得注意&#xff0c;下面小编与大家分享一下如何注…

Ubuntu安装完后设置root密码

安装完Ubuntu 14.04后默认是没有主动设置root密码的&#xff0c;也就无法进入根用户。 相关阅读&#xff1a; Ubuntu 14.04 下载、安装、配置 整理汇总 页面 http://www.linuxidc.com/Linux/2014-04/100370.htm Windows 7下硬盘安装Ubuntu 14.04永久更新地址&#xff1a; http:…

js 中转换成list集合_程序员:java集合介绍-List,具说很详细,你不来看看?

Java集合介绍作为一个程序猿&#xff0c;Java集合类可以说是我们在工作中运用最多、最频繁的类。相比于数组(Array)来说&#xff0c;集合类的长度可变&#xff0c;更加方便开发。Java集合就像一个容器&#xff0c;可以存储任何类型的数据&#xff0c;也可以结合泛型来存储具体的…

axure实现搜索功能_vue实现模糊搜索功能

首先写好一个列表写好的样式是这样滴操作来了在computed里面定义了一个search函数 使用filter过滤接下来在method 里面写一个sousuo1函数 进行一个判断 如果搜索这个输入框框里是空 就是展示原数据 如果这个不为空 就会展示搜索到的数据最后 很重要把list改为sousuo1()这个函数…

7000更换控制器电源步骤_开关电源控制环路(初级篇:上)

本文是 21Dianyuan 社区原创技术文章&#xff0c;作者 ctus220&#xff0c;感谢作者的辛苦付出。内容目录&#xff1a;1、环路和直流稳压电源的关系2、与环路相关的基本概念波特图&#xff0c;环路稳定性判据&#xff0c;传递函数&#xff0c;零极点3、常用的补偿控制器PI&…

python实现排列组合公式算法_朴素贝叶斯算法的Python实现

朴素贝叶斯分类算法被广泛应用于文本分类场景中、包含垃圾邮件、互联网新闻等分类任务&#xff0c;属于有监督学习算法。它独立考量每一维度特征被分类的条件概率&#xff0c;然后综合这些概率对其所在的特征向量做出分类预测&#xff0c;即“假设各个维度上的特征被分类的条件…

cdr怎么做文字路径_整理128张图片,告诉你文字少的PPT应该怎么做?

点击上方蓝字关注↑&#xff0c;下次看文更方便&#xff01;微信扫码观看全套Excel、Word、PPT视频作者&#xff1a;自律的音律 来源&#xff1a;自律的音律(ID&#xff1a;yinlvPPT)哈喽&#xff0c;又到周一干货时间。我经常被问到一个问题&#xff0c;PPT 字多的时候&#…