谈谈JAVA程序的反编译

21 views
Skip to first unread message

gmail

unread,
Jun 12, 2008, 11:50:12 PM6/12/08
to MY google bbs
谈谈JAVA程序的反编译

阅读次数: 45872次 发布时间: 2001-10-07 08:00:00发布人:


来源:

Sina.com.cn 于瑶 

  如今JAVA语言在全世界范围正如火如荼般的流行,它广范地应用在INTERNET的数据库、多媒体、CGI、及动态网页的制作方面。1999年在美国对JAVA程序员的需求量首次超过C++! 

  作者因最近分析一些JAVA程序,对JAVA的反编译进行了一番了解,下面将我所了解的情况作以下介绍,希望对JAVA爱好者有所帮助。 

  JAVA是采用一种称做"字节编码"的程序结构,分为小程序(嵌入到HTML文件中)和应用程序(直接在命令状态下执行)两种类型。无论哪种结构,一旦用JAVAC 命令编译后,均变成后缀为CLASS的同名可执行文件。这种文件是不可阅读的代码。 

  经查阅了SUN公司的JDK(JDK1.1.3)文档资料后,我找到了一个据称是可反编译JAVA的JAVAP文件(EXE),这个文件位于\JDK\BIN\ 下面,经按说明使用后,感到失望,原来这个"反编译"仅可反编译出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:\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 

  得到的源文件: 

  /* 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表示敬意,感谢他给我们留下这个工具软件。 

Sina.com.cn 于瑶   如今JAVA语言在全世界范围正如火如荼般的流行,它广范地应用在INTERNET的数据库、多媒体、CGI、及动态网页的制作方面。1999年在美国对JAVA程序员的需求量首次超过C++!   作者因最近分析一些JAVA程序,对JAVA的反编译进行了一番了解,下面将我所了解的情况作以下介绍,希望对JAVA爱好者有所帮助。   JAVA是采用一种称做"字节编码"的程序结构,分为小程序(嵌入到HTML文件中)和应用程序(直接在命令状态下执行)两种类型。无论哪种结构,一旦用JAVAC 命令编译后,均变成后缀为CLASS的同名可执行文件。这种文件是不可阅读的代码。   经查阅了SUN公司的JDK(JDK1.1.3)文档资料后,我找到了一个据称是可反编译JAVA的JAVAP文件(EXE),这个文件位于\JDK\BIN\ 下面,经按说明使用后,感到失望,原来这个"反编译"仅可反编译出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:\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   得到的源文件:   /* 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表示敬意,感谢他给我们留下这个工具软件。

gmail

unread,
Jun 12, 2008, 11:54:49 PM6/12/08
to MY google bbs

转载  java反编译工具jad

新一篇: 常用正则表达式

http://www.kpdus.com/jad.html  官方最新版本,支持jdk1.6

Java下的一个简单易用的反编译工具jad, 可以很方便的将.class反编译为.Java. 点击下载 

一、基本用法
Usage:jad [option(s)]
直接输入类文件名,且支持通配符,如下所示。
c:\Java\>jad example1.class
c:\Java\>jad *.class
结果是将example1.class反编译为example1.jad。将example1.jad改为example1.Java即得源文件。

二、Option -o
不提示,覆盖源文件

三、Option -s
c:\Java\>jad -sJava example1.class
反编译结果以.Java为扩展名。

四、Option -p
将反编译结果输出到屏幕
c:\Java\>jad -p example1.class
将反编译结果重定向到文件
c:\Java\>jad -p example1.class>example1.Java

五、Option -d
指定反编译的输出文件目录
c:\Java\>jad -o -dtest -sJava *.class

该文章转载自网络大本营:http://www.haoad.net/Info/3883.Html 

  反编译别人的程序是不对的,但是有时候由于某种原因,不得不反编译别人的代码,那就需要一个工具了。小颖JAVA源代码反编译专家V1.4终极版是个很好的工具,但是只能对JDK1.4.2和之前的版本编译的程序反编译,而JDK5.0后的就无能为力了,但是可以下载JAD.EXE来逐个反编译 CLASS文件,不过如果碰到有几十个或几百个文件夹,并且目录很深的时候,就麻烦了,这个给出一个直接使用命令行反编译整个目录的方法:使用jad批量反编译

jad -o -r -sjava -d src bin/**/*.class

src: 是反組後的目錄

bin:指 package 開頭

将bin里面所有的.class反编译到src下面JAD下载: 文件名: jadnt157.ziphttp://download.pchome.net/php/dl.php?sid=9111


jad:反编译工具
可以将class文件反编译成java文件
假设将jad.exe安装在f:\java\jad目录下
把要反编译的文件*.class复制到此目录下,接着接以下步骤,
在命令行窗口环境中进入jad目录,
然后运行:jad -s java *.class  (附,*.class指要反编译的文件名)
如果*.class文件和jad程序不在同一个目录,就要用到path环境变量,
将jad 所在目录加到path路径中即可:set path=%path%;f:\java\jad
若要了解jad更为详细的使用帮助信息,直接运行jad.exe查看

以下假设jad.exe在c:\java目录下

一、基本用法
Usage:jad [option(s)]
直接输入类文件名,且支持通配符,如下所示。
c:\java\>jad example1.class
c:\java\>jad *.class
结果是将example1.class反编译为example1.jad。将example1.jad改为example1.java即得源文件。

二、Option -o
不提示,覆盖源文件

三、Option -s
c:\java\>jad -sjava example1.class
反编译结果以.java为扩展名。

四、Option -p
将反编译结果输出到屏幕
c:\java\>jad -p example1.class
将反编译结果重定向到文件
c:\java\>jad -p example1.class>example1.java

五、Option -d
指定反编译的输出文件目录
c:\java\>jad -o -dtest -sjava *.class

六、Option -r
按*.class的包结构输出文件目录
c:\java\>jad -o -r -dtest -sjava d:/1/**/*.class
将d:\1\文件夹下的.class文件按照原程序的包结构反编译到test目录下。 

from : http://blog.csdn.net/qingtanlang/archive/2007/07/13/1688250.aspx

gmail

unread,
Jun 12, 2008, 11:56:03 PM6/12/08
to MY google bbs
 
Mocha, the Java Decompiler

 

gmail

unread,
Jun 12, 2008, 11:58:42 PM6/12/08
to MY google bbs
Jad - the fast JAva Decompiler
 
Reply all
Reply to author
Forward
0 new messages