现在JAVA语言在全世界范围正如火如荼般的流行,它广范地应用在INTERNET的数据库、多媒体、CGI、及动态网页的制做方面。1999年在美国对JAVA程序员的需求量首次超过C++!java 做者因最近分析一些JAVA程序,对JAVA的反编译进行了一番了解,下面将我所了解的状况做如下介绍,但愿对JAVA爱好者有所帮助。程序员 JAVA是采用一种称作“字节编码”的程序结构,分为小程序(嵌入到HTML文件中)和应用程序(直接在命令状态下执行)两种类型。不管哪一种结构,一旦用JAVAC 命令编译后,均变成后缀为CLASS的同名可执行文件。这种文件是不可阅读的代码。数据库 经查阅了SUN公司的JDK(JDK1.1.3)文档资料后,我找到了一个据称是可反编译JAVA的JAVAP文件(EXE),这个文件位于\JDK\BIN\ 下面,经按说明使用后,感到失望,原来这个“反编译”仅可反编译出JAVA程序的数据区(定义)、若干方法和类的引用等。小程序 这里我用了一个简单例子来讲明问题。app JAVA的源程序hello_java.java以下:工具 <pre class="java" name="code"><span style="font-size:18px;">import java.applet.*; import java.awt.*; public class hello_java extends Applet { public void paint(Graphics g) { g.drawString("Hello Java!\n",20,20); } } </span>
经用反编译命令:javap -c -package -public -private hello_java hello.java编码 获得的反编译结果(hello.java)以下:(有关javap命令的选择参数请见其使用说明,这里-c表示选择了反编译)spa <span style="font-size:18px;">Compiled from hello_java.java public synchronized class hello_java extends java.applet.Applet /* ACC_SUPER bit set */ { public void paint(java.awt.Graphics); public hello_java(); Method void paint(java.awt.Graphics) 0 aload_1 1 ldc #1 3 bipush 20 5 bipush 20 7 invokevirtual #6 10 return Method hello_java() 0 aload_0 1 invokespecial #5 ()V> 4 return } </span>
从上述结果不难看出该反编译未能将源程序全译出来,像语句g.drawString("Hello Java!\n",20,20); 就没有。随着程序量增长,未能编译的JAVA语句还会更多。因此这个反编译程序仅能起个参考做用。.net 幸好有了INTERNET,笔者经过YAHOO很快找到了一个JAVA反编译“自由软件”(SHAREWARE),http://www.inter.nl.net/users/H.P.van.Vliet/mocha.htm 。 这个软件叫MOCHA,听说是一位30来岁的加拿大的研究生所完成,仅是个“?”版,缘由是这位叫作H.P.VAN.VLIET的小伙子患癌逝世了,十分惋惜呀!code 经使用MOCHA反编译软件,感到这个软件十分好用,笔者试反编译多个JAVA程序,均获得很好的结果。 这里给出如何使用这个软件,首先,用WINZIP等将"mocha-b1.zip" 解开获得"mocha.zip"文件,"mocha.zip"不须再解开,这个包内包括了反编译的类文件,只需将其拷贝到JDK所在的目录下,如:c:\jdk\bin\ 此外,须设置路径:SET CLASSPATH=c:\myclasses;c:\jdk\bin\mocha.zip MOCHA用法: java mocha.Decompiler [-v] [-o] Class1.class Class2.class ... "java" 调用Java虚拟机 "mocha.Decompiler" 指示要进行JAVA反编译 "-v" 选择详细输出 "-o" 选写入已有的.mocha 文件 "ClassX.class" 指出要反编译类名 注意,不需给出输出的JAVA文件名,由于MOCHA自动产生一个与CLASS同名但扩展名为MOCHA的JAVA源文件。 对于上例,可用命令: java mocha.Decompiler [-v] [-o] hello_java.class 获得的源文件: <span style="font-size:18px;">/* Decompiled by Mocha from hello_java.class */ /* Originally compiled from hello_java.java */ import java.applet.Applet; import java.awt.Graphics; public synchronized class hello_java extends Applet { public void paint(Graphics g) { g.drawString("Hello Java!\n", 20, 20); } public hello_java() { } } </span>
咱们不难发现,此文件与编译前的JAVA源文件彻底同样!笔者曾经用MOCHA反编译出最大为80K的源文件,均取得成功。 在此,笔者向英年早逝的VLIET表示敬意,感谢他给咱们留下这个工具软件。 |