在对JavaScript代码进行混淆加密时,经常会用到平展控制流,它可以将代码“展开”、打乱逻辑流程。
与之相对的,还有一种不常见的收缩控制流技术,可以将多行代码“收缩”到一行。

以下用示例展示两者各自的效果。
平展控制流:
使用JShaman(专业的JS代码加密平台)对一段代码进行平展控制流操作,如下图:

处理后,代码将发生如下变化:

可见,平展操作之后,打乱了代码顺序,并且代码量也增加了。是种不错的JS代码混淆加密手段。
再来看收缩控制流,效果如下:

代码中,比如a和b变量的赋值,原本是分别在两行中进行。而收缩之后,变成在一行中完成:

这个方式,同样起到了混淆代码逻辑的效果。
用astexplorer查看代码的AST(抽象语法树),处理前:

处理后:

可见,AST同样得到了收缩。
此外,与平展控制流相比,它还具有一项优势:
可以压缩代码量、并可提高代码执行效率。
如下图所示,处理前代码长度为226,之后变成了218。

而且,此技术生成的代码将多个赋值语句转为了逗号连续语句,也会提升代码执行性能。
如下图所示,此次测试中,处理前的原始代码执行消耗0.277ms,处理后消耗0.107ms。

本文探讨了JavaScript代码混淆中的平展控制流和收缩控制流技巧,前者打乱逻辑并增加代码量,后者则压缩代码并提升执行效率。通过实例和AST比较,揭示了这两种技术在混淆加密中的作用和优劣。

被折叠的 条评论
为什么被折叠?



