[数据安全] 一个简洁快速的去数据特征的混淆算法(obfuscate)

2023-10-17 16:10

本文主要是介绍[数据安全] 一个简洁快速的去数据特征的混淆算法(obfuscate),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[注]本文为作者原创文章,转载请注明出处。谢谢。 

 

问题1,什么是特征

  这个人长个马脸,那个妹子胸大,这都是特征。显然,特征越明显,我们越容易对其进行辨识。

问题2,什么是数据特征

  数据特征,就是说,某段数据具有的特征。

    比如,通迅的双方(A <-> B ),在建立连接后,A发给B的第一个包,长度总是固定的,有时候甚至值都是固定的(在协议握手阶段尤其如此)。 

问题3,为什么要去掉这些特征

  我们在讲网络安全的时候,绝大部分的人能想到数据加密,然而仅仅加密还不足于保护我们的。下面我举几个例子。

    1,某FW在对数据包进行检测的时候,可以通过特征的学习及辨识去决定要不要reset这个连接。

    2,浏览网站时产生的流量数据,带有明显的网页字节数特征,通过对这个特征的学习,第三方可以大概知道浏览网站的人都访问过哪些网站,甚至知道访问了哪些页面。 

问题4,怎么去数据特征

  通过粗略的分析,我们至少有两个办法可以使数据特征不明显。

    1,改变数据长度。主要通过在数据流中加入一些随机长度的随机值。

    2,通过增加冗余位,增加数据中具体位的随机性。 

一种冗余位Obfuscate方案

  我们知道一个字节通常由8个bit组成。确定的值,它的bit平面(低位到高位所呈现的0101序列)总是确定的。如果我们让这个确定变成不确定,我们的目的就达成了。

  下面,我介绍一个简单的通过冗余位达到混扰的目的。

  以uint8_t -> uint32_t 为实例进行一个大概的算法描述  

  uint8_t   占8bit

  uint32_t   占32bit  

  uint8_t中

    01位置于uint32_t 第一个byte,

    23位置于uint32_t第二个byte,

    45位置于uint32_t第三个byte,

    67位置于uint32_t第四byte

 

    具体的算法:

     取uint32_t中每个byte的高3位,得到一个数值p, p mod 5 = z, z就是这个byte中起始有效bit位,从这个位开始,顺序存储(从底位到高位)2个uint8_t中的位 (见下图)

   

  

 C代码实现

//UINT_X's width must be less than sizeof(uint32_t), it can be uint8_t or , uint16_t
template <typename UINT_X>
inline static uint32_t obfuscate(UINT_X const& val, uint32_t const& r_u32) {if (sizeof(uint32_t) <= sizeof(UINT_X)) return val;uint32_t rr = 0;uint8_t b[sizeof(UINT_X) * 8];uint8_t bii[sizeof(UINT_X) * 8];//per bytes contain bit countuint8_t pbcbc = (sizeof(UINT_X) * 8) / (sizeof(uint32_t) / sizeof(uint8_t));for (int i = 0; i < (sizeof(UINT_X) * 8); i++) {if ((i%pbcbc) == 0) {b[i] = ((r_u32 >> ((5 + ((i / pbcbc) << 3))) & 0x7) % 5) & 0xFF;bii[i] = b[i];} else {b[i] = ((b[i - 1] + 1) % 5);bii[i] = bii[i - 1];}uint8_t bi = 0;if (val&(0x01 << i)) {bi |= (0x01 << b[i]);}bi |= ((0x7 & bii[i]) << 5);rr |= ((0xFFFFFFFF & bi) << ((i / pbcbc) << 3));}return rr;
}template <typename UINT_X>
inline static UINT_X deobfuscate(uint32_t const& val) {UINT_X r = 0;uint8_t pbcbc = (sizeof(UINT_X) * 8) / (sizeof(uint32_t) / sizeof(uint8_t));UINT_X b[sizeof(UINT_X) * 8];for (int i = 0; i < (sizeof(UINT_X) * 8); i++) {if ((i%pbcbc) == 0) {b[i] = ((val >> ((5 + ((i / pbcbc) << 3))) & 0x7) % 5) & 0xFF;} else {b[i] = ((b[i - 1] + 1) % 5);}r |= (((val >> (b[i] + ((i / pbcbc) << 3))) & 0x1) << i);}return r;
}namespace wawo { namespace security {inline static uint32_t u8_obfuscate(uint8_t const& val, uint32_t const& r_u32) {return obfuscate<uint8_t>(val,r_u32);}inline static uint32_t u16_obfuscate(uint16_t const& val, uint32_t const& r_u32) {return obfuscate<uint16_t>(val, r_u32);}inline static uint8_t u8_deobfuscate(uint32_t const& val) {return deobfuscate<uint8_t>(val);}inline static uint16_t u16_deobfuscate(uint32_t const& val) {return deobfuscate<uint16_t>(val);}
}}

  

  

 

   

 

 

 

 

    

转载于:https://www.cnblogs.com/copys/p/5568169.html

这篇关于[数据安全] 一个简洁快速的去数据特征的混淆算法(obfuscate)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元

Linux lvm实例之如何创建一个专用于MySQL数据存储的LVM卷组

《Linuxlvm实例之如何创建一个专用于MySQL数据存储的LVM卷组》:本文主要介绍使用Linux创建一个专用于MySQL数据存储的LVM卷组的实例,具有很好的参考价值,希望对大家有所帮助,... 目录在Centos 7上创建卷China编程组并配置mysql数据目录1. 检查现有磁盘2. 创建物理卷3. 创

Nacos日志与Raft的数据清理指南

《Nacos日志与Raft的数据清理指南》随着运行时间的增长,Nacos的日志文件(logs/)和Raft持久化数据(data/protocol/raft/)可能会占用大量磁盘空间,影响系统稳定性,本... 目录引言1. Nacos 日志文件(logs/ 目录)清理1.1 日志文件的作用1.2 是否可以删除

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1