java程序加密的另一种实现方法

众所周知,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解释器运行,就可以达到加密,而且加密的强度由自己指定。以此加密过程完成。

你可能感兴趣的:(java)