当前位置: 首页 > news >正文

eclipse与jsp网站开发企业宣传片制作模板

eclipse与jsp网站开发,企业宣传片制作模板,免费模版网,外贸网站建设基础二进制明文字符串加密:实现原理 背景 这里就不多做解释了,明文字符串暴露就是最好的逆向分析指引。无论是恶意攻击样本还是有一定安全需求的组件,直接暴露程序中的明文字符串会大幅降低外部的分析成本。所以需要在编译出的二进制中隐藏字符串。不过需要…

二进制明文字符串加密:实现原理

背景

这里就不多做解释了,明文字符串暴露就是最好的逆向分析指引。无论是恶意攻击样本还是有一定安全需求的组件,直接暴露程序中的明文字符串会大幅降低外部的分析成本。所以需要在编译出的二进制中隐藏字符串。不过需要明确下字符串加密的实现主要分两种,一种是借助llvm的pass去做的,另外一种是基于编译期模板的形式去做的,这里讨论的是后者。

常规的字符串表示

代码和16进制如下

printf("conventional...\n");

在这里插入图片描述

解决明文暴露的问题

首先考虑转换下写法,代码和16进制如下

char strArray[] = { 'c', 'o', 'n', 'v', 'e', 'n', 't','i', 'o', 'n', 'a', 'l', '.', '.', '.', '\n', '\0' };
printf(strArray);

在这里插入图片描述

这么写似乎和直接写字符串编译后没有区别?但是将字符串转为字符数组表示便于下面的加密逻辑

char strArray[] = { 'c' + 1, 'o' + 1, 'n' + 1, 'v' + 1, 'e' + 1, 'n' + 1, 't' + 1,'i' + 1, 'o' + 1, 'n' + 1, 'a' + 1, 'l' + 1, '.' + 1, '.' + 1, '.' + 1, '\n' + 1, '\0' + 1 };
for (unsigned int index = 0; index < sizeof(strArray); index++)
{strArray[index] -= 1;
}
printf(strArray);

在这里插入图片描述

可以看到实际每个字符以+1的模式存储,在使用前进行解密,从而实现明文字符串隐藏,同时这里的核心在于依靠编译器优化使得加密过程(这里指+1)在编译期可以直接算出加密后的结果,从而在编译完成的二进制中直接保存密文,而运行时进行解密从而使得实际结果保持不变。这里的两个需求非常重要,如果有一个不满足即会导致失败,这里将这两个总目标单独列出

  1. 编译期可以直接算出加密后的结果
  2. 运行时进行解密

实现上述过程

当然我们不可能每次隐藏字符串的时候都要手动去编写类似上述的代码,而希望有一个自动生成上述代码的方式。所以xorstr的核心目的就是如果将上面的写法用C++模板自动生成,并且确保总结出的两个核心目标{编译期可以直接算出加密后的结果}和{运行时进行解密}

两个开源实现如:andrivet/ADVobfuscator以及JustasMasiulis/xorstr

两个实现都稍显复杂,下面写个最小概念代码验证可行性

**我们需要的使用形式:**我们希望使用起来和正常字符串使用差不多,代码如下

#define Enc(str) EncryptString(str).decrypt()
printf(Enc("encrypt string?"));

因此我们需要EncryptString返回一个类的实例化对象,然后调用该对象的decrypt成员函数完成解密,代码如下

template<size_t N>
class EncryptString
{
public:template<size_t... Index>constexpr EncryptString(const char* plainString, std::index_sequence<Index...>): encBuffer{ (plainString[Index] + 1)... }{}__forceinline char* decrypt(){for (auto index = 0; index < N; index++){encBuffer[index] -= 1;}return encBuffer;}
private:char encBuffer[N];
};#define Enc(str) EncryptString<sizeof(str)>(str, std::make_index_sequence<sizeof(str)>{}).decrypt()printf(Enc("conventional...\n"));

在这里插入图片描述

可以看到上述代码成功实现了我们的预定目标,实现方式概述:编译期求解字符串数组长度利用模板技术生成一个该字符串数组的加解密类,类的构造函数使用C++变参模板展开和std::index_sequence的方法实现对字符串中每个元素的提取和加密,同时保障上述过程编译时完成。同时解释下为什么这里既然所有字符串的decrypt的逻辑都是一样的,为什么还要把他实现成类的成员函数呢?因为如果设计成统一的外部解密函数会被反编译引用查找的方式找到统一的入口,大大降低分析的难度

对抗

介绍完原理下篇文章会详细介绍下:xorstr的还原 & xorstr还原的对抗

http://www.yayakq.cn/news/908086/

相关文章:

  • 想自己做个网站在哪里做1元免备案虚拟主机
  • 客户说做网站价格高给客户做网站需要提供
  • 网站做直播吗办公室装修设计效果
  • 门户网站建设方案 模板网站建设汇报方案ppt模板
  • 膜结构网站推广怎么做家装公司哪家比较好
  • 惠安网站建设价格一级a做片性视频网站
  • 怎样做某个网站有更新的提醒做特效很牛的一个外国网站
  • 重庆九龙坡营销型网站建设公司哪家专业百度搜索排名服务
  • 想要网站导航正式推广网站策划软件
  • 本地网站asp iis子域名网址查询
  • 上海装修公司网站建设云浮新兴县做网站
  • 湖南基础建设投资集团网站1688会提供网站建设
  • 昆山建设企业网站wordpress集成关注公众和登陆
  • 焦作住房和城乡建设厅网站分类目录 代码 wordpress
  • 照片书哪家网站做的好茂名模板建站定制网站
  • 建设银行网站背景中国手工加工网免费供料
  • 河东网站建设公司北京做网站的价格
  • 推荐ps制作网站效果图太仓苏州网站建设
  • 巫山那家做网站厉害手机微信小程序开发教程
  • 乐山网站建设公司wordpress赞助
  • 企业专业网站建设哪家好wordpress 文章数据
  • 济南网站建设价格公司装修工程
  • 给公司怎么做官方网站园林景观设计平面图
  • 首页网站怎么做的网页开发背景怎么写
  • 2015做啥网站致富网站建设网站免费
  • 钱网站制作asp.net+h5网站开发
  • 设计本室内设计师网谷歌seo济南
  • 怎么制作一个网站东营做网站公司
  • 东莞网站排名优化公司做的网站没给我备案
  • 广州建站方法赣州开发区网站建设