前言
通常而言, Java程序很容易被烂大街的反编译器 (如JD-GUI, Luyten等) 反编译出源代码并且进行未授权的修改. 所以很多开发者会用 ProGuard 等解决方案来对他们的Java程序进行最基础的保护.
但是经过 ProGuard 保护的程序仍然可以反编译出可以编译的源码并且推测出类的作用. 这时候字节码混淆器就显得尤为重要了.
字节码混淆器可以通过不同的方法对字节码进行乱序 插入花指令 数据加密等保护, 很大程度上保护了Java程序免受到破解
> 展示
本人 (微信: UniRhyme) 自己编写的字节码混淆器保护后的程序反编译结果
这你看得懂?
原理
我这里使用了 ObjectWeb 所开发的 ASM 库对 Java 的字节码进行修改, 从底层对程序进行了保护
例如字符串加密 其流程为
生成解密器 -> 加密字符串 -> 替换加载指令
源码截图:
这样一来, 字符串会变成