众所周知,java程序在生成jar文件后,通过专门的软件可以反编译出原文件,还原程序接近98%。
反编译的工具有:
jad
xjad
front end plus
mdejava
decafe pro
cavaj java decompiler
dj java decompiler
nmi’s java class viewer
国产的java源代码反编译专家
大多数反编译工具,均采用的是jad的核心引擎
目前java加密中大多采用的为混淆代码加密的方式,这样虽然初步可以对代码进行保护,但无法提供彻底的保护
java程序生成后文件为中间字节码形式保存的,无法像普通的win32程序通过加壳来达到保护代码的目的,这里便提出一个问题,怎样来保护自己写的代码不被反编译出来。
在jar程序运行时,启动的进程为java -jar test.jar, 通过java的核心程序java.exe来加载test.jar到内存中进行字节码的转换,把字节码转换为win32上可执行的代码运行。
首先test.jar文件不能进行修改,否则java解释器不能正确的解释中间码,我们要加密的部分也在这里,加上自己的一层中间字节码转换,再提交给java解释器运行,就可以达到加密,而且加密的强度由自己指定。以此加密过程完成。
======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/