WEB开发网
开发学院WEB开发Jsp 谈谈JAVA的反编译 阅读

谈谈JAVA的反编译

 2008-01-05 09:49:02 来源:WEB开发网   
核心提示:作者因最近分析一些java程序,对JAVA的反编译进行了一番了解,谈谈JAVA的反编译,下面将我所了解的情况作以下介绍,希望对JAVA爱好者有所帮助,如读者下载MOCHA有困难,可给笔者来电子邮件,JAVA是采用一种称做“字节编码”的程序结构,分为小程序(嵌入到Html文件中)和应用程序(直接在命令状态下执行)两种类型

  作者因最近分析一些java程序,对JAVA的反编译进行了一番了解,下面将我所了解的情况作以下介绍,希望对JAVA爱好者有所帮助。
  
  JAVA是采用一种称做“字节编码”的程序结构,分为小程序(嵌入到Html文件中)和应用程序(直接在命令状态下执行)两种类型。无论哪种结构,一旦用JAVAC 命令编译后,均变成后缀为CLASS的同名可执行文件。这种文件是不可阅读的代码。
  经查阅了SUN公司的JDK(JDK1.1.3)文档资料后,我找到了一个据称是可反编译JAVA的JAVAP文件(EXE),这个文件位于JDKBIN 下面,经按说明使用后,感到失望,原来这个“反编译”仅可反编译出JAVA程序的数据区(定义)、若干方法和类的引用等。
  
  这里我用了一个简单例子来说明问题。
  JAVA的源程序hello_java.java如下:
  
  import java.applet.*;
  import java.awt.*;
  
  public class hello_java extends Applet
  {
  public void paint(Graphics g)
  {
  g.drawString("Hello Java!n",20,20);
  }
  }
  
  经用反编译命令:javap -c -package -public -PRivate hello_java hello.java
  得到的反编译结果(hello.java)如下:(有关javap命令的选择参数请见其使用说明,这里-c表示选择了反编译)
  
  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
  }
  
  从上述结果不难看出该反编译未能将源程序全译出来,像语句g.drawString("Hello Java!n",20,20); 就没有。随着程序量增加,未能编译的JAVA语句还会更多。所以这个反编译程序仅能起个参考作用。
  幸亏有了INTERNET,笔者通过YAHOO很快找到了一个JAVA反编译“自由软件”(SHAREWARE),http://www.inter.nl.net/users/H.P.van.Vliet/mocha.htm 。 这个软件叫MOCHA,据说是一位30来岁的加拿大的研究生所完成,仅是个“?”版,原因是这位叫做H.P.VAN.VLIET的小伙子患癌逝世了,十分可惜呀!
  经使用MOCHA反编译软件,感到这个软件十分好用,笔者试反编译多个JAVA程序,均得到很好的结果。
  这里给出如何使用这个软件,首先,用WinZip等将"mocha-b1.zip" 解开得到"mocha.zip"文件,"mocha.zip"不须再解开,这个包内包括了反编译的类文件,只需将其拷贝到JDK所在的目录下,如:c:jdkbin 此外,须设置路径:SET CLASSPATH=c:myclasses;c:jdkbinmocha.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
  得到的源文件:
  /* 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()
  {
  }
  }
  我们不难发现,此文件与编译前的JAVA源文件完全一样!笔者曾经用MOCHA反编译出最大为80K的源文件,均取得成功。
  在此,笔者向英年早逝的VLIET表示敬意,感谢他给我们留下这个工具软件。
  如读者下载MOCHA有困难,可给笔者来电子邮件,笔者可将MOCHA寄去。
  
  参考文献:
  1) http://www.inter.nl.net/users/H.P.van.Vliet/mocha.htm
  2) http://www.javasoft.com
  3) http://java.sun.com
  4) http://www.yahoo.com

Tags:谈谈 JAVA 编译

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接