代码保护(三) java代码保护方案

本文介绍了Java代码保护的两种方法:一是使用ProGuard进行代码混淆,增加反编译难度;二是通过Excelsior JET将Java程序转化为C++可执行文件,提高逆向工程的复杂度。最后提到了使用VMProtect等工具进行加壳保护,以增强程序安全性。

Java防止反编译的一种解决方案

一、使用ProGuard对代码进行混淆

1   下载并启动ProGuard代码混淆器

2   Input/output中选择要加密的Jar文件,并导入该项目使用的Jar

 

3   设置混淆参数选项

4   保存混淆配置

5   重新启动ProGuard载入保存的配置文件

6   混淆成功

7   使用JD-gui反编译软件进行混淆前后对比

结论:使用代码混淆仅增加了程序理解的难度,程序的逻辑及流程仍然清晰可见,(但可以将函数名、参数名、设置的更凌乱一些,进一步增加阅读难度)。

二、使用Excelsior JET将java可执行程序转化为C++可执行程序

1   安装并启动Excelsior JET

 

 

 

2   发布运行

3   再系统盘内找不到该程序运行的jar文件,通过查壳工具PEID查看该可执行文件,未加密

4   通过静态反汇编工具OD查看该文件汇编代码

 

至此,对该java项目的逆向工程的难度同C++写的程序一样困难,较难以得到程序的源代码。在此操作之上还可以进一步采取手段阻挠对源代码的逆向工程,如下所示的加壳操作。

三、使用VMProtect等工具对.exe文件进行加壳保护

1   使用VMProtect工具对该程序加壳

2   在使用VirboxProtector增加第二层保护壳时弹出如下提醒

猜测是VMProtect已经进行了虚拟化保护,在使用同样机制的VirboxProtector加密后出现了一些问题。

3   在使用UPX加壳软件增加第二层保护壳时同样提醒出现了错误

这表明已经成功的对该软件增加了VMP保护壳,软件的安全性得到了进一步的提升。

 

 

众所周知,java开发语言提供了很方便的开发平台,而且开发出来的程序很容易在不同的平台上面进行移植,现在越来越多的人使用它开发软件。 Java有了它方便的一个方面,但是他同时也带给了开发者一个烦恼,这就是保护的办法不多,而且大多数不是很好用,这样自己辛苦开发出来的程序很容易被人反编译过来而据为己有,一般情况下,大多数的人都是用混编器(java obfuscator)来把开发出来的程序进行打乱以达到没有办法来反编译观看源代码,但是这种办法在网上很容易找到相关的软件来重新整理,那么这个混编只能控制一些本来也没有办法动您的软件的人,而对于一些掌握工具的人几乎是透明的,还有就是利用硬件加密锁,但大多数公司提供的硬件加密锁只是提供了一些dll的连接或简单的api调用,只要反编译他们,就很容易把一些api调用去掉,这样硬件加密锁也就不起作用了,但是现在到底有没有好的办法呢? 市场上现有的几款防止反编译工具其实都是改进了加载过程。但是加载到JAVA虚拟机后一样可以得到CLASS字节码的。 只要懂JAVA原理的人其实很用意破解的. JAVACOMPILE 这款工具就不一样了,javacompile 它是修改了虚拟机内核, 用户目录里没有需要的JAVA字节码,而是当JAVA需要调用函数的时候才通过网络下载相对应的已经二次编译的字节码,就算用户通过 CLASS.getClass 也得不到可以用来反编译字节码。 真正意义上保护JAVA知识产权。 个人版限制编译30个CLASS文件,文件打包方式下载。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值