[数据安全] 一个简洁快速的去数据特征的混淆算法(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

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片