刚发布了一个java反编译+UI辅助工具ClassExplorer在这里下载反编译引擎是自己写的,一次发布到公共网络上,
UI辅助工具包含很多方便的功能,可以直接查看jar文件、可以模糊查找类名、查看继承关系、查找引用、查找字符串等。
欢迎大家去试用一下。
UI辅助工具包含很多方便的功能,可以直接查看jar文件、可以模糊查找类名、查看继承关系、查找引用、查找字符串等。
欢迎大家去试用一下。
运行程序后按F1也可以看到这个页面。反编译的源代码是不需要任何调试信息的。
IDE里能看到JRE/JDK的源代码那是因为JDK自带源代码的,通常是JDK目录下的src.zip
其他的jar也是可以配置源文件路径的(如果有)在ClassExplorer里,你选中XXXXX.class点击鼠标右键,弹出菜单里有"View Decompiled Source"。
public static void main(String[] args){
try {
int a = Integer.parseInt("1fs");
} catch (Exception e) {
e.printStackTrace();
} finally {
System.out.println("finally");
}
}}
我写了一个类来测试能否反编译Exception,代码如上,反编译代码如下:
public class CommonTesting
{
public CommonTesting()
{
super();
return;
} public static void main(String[] args)
{
try
{
int a = Integer.parseInt("1fs");
} catch(Exception e)
{
e.printStackTrace();
} finally
{
System.out.println("finally");
} System.out.println("finally");
return;
}}为什么会多了一行System.out.println("finally");呢?
1、解析java class的binary code
2、根据这些binary code猜测可能是怎样的java源代码编译生成的。
由于sun 对java class编译有相应的规范,所以反编译java class相对反编译其他语言程序还是容易得多的。但毕竟是猜测出的源代码,不太可能做到完全准确的反编译。jad等工具虽然比我这个强,但同样不能完全反编译。
这类工具只是用来学习研究的,要反编译出来的程序完全符合java规范并可再编译成class是不现实的。
其中反编译引擎是几年前写的,现在想改也不是那么容易的事情了。你上面的程序以多出一个System.out.println("finally");确实是我的反编译引擎能力不足。
原因是这样的:
现在的编译器(Eclipse自带的)里有个选项是Inline finally blocks。编译后的java class把每一个可能运行到的分支直接插入finally里的代码。有多少个分支就有多少份。上面的程序有一个异常分支和一个正常分支,就有两个finally代码。当初分析代码的时候没有考虑过这种情况。
对我来说,最难的是循环(for/while/do)的分析,尤其是嵌套循环再加上if语句,class里的代码就是跳来跳去,很难准确的分析出java源代码。你可以用JDK 里的javap -c看看class的byte code是什么样子的。
http://java.decompiler.free.fr/