程序员工具癖

用jad做一个快乐的java代码阅读师

2019-03-03  本文已影响10人  cleanup123

对于我们大多数java代码的开发者,阅读已经编译好的class文件是我们经常要做的事情。最常见的方法无外乎使用IDE(eclipse、idea)自带的反编译功能。

那如果在没有源码的情况下需要对class文件批量反编译需要如何做呢?

1、使用jad-gui。这对于少量代码是可行的,通常来讲一个jar包中的代码量可不是”少量“的。如下图,如果使用jad-gui,导出整个jar包的内容需要手工创建多个java文件,以及目录层级,这显然不是可以用人工去做的。

jad-gui.png

2、就是使用我们今天的主角jad。下面我就来为大家仔细的说明一下jad的使用方法。


jad.png

以下是jad工具的使用命令

jad命令详解.png

那么下面给大家讲解一下常用的常规操作
安装配置

下载好jad(https://varaneckas.com/jad/)之后。给jad.exe配置环境变量或者将jad.exe放到C:\Windows\System32目录下。通过cmd命令进入windows命令窗口模式。

我们现在通过反编译来获取druid-1.1.10的代码。
1.先将jar包用解压工具解压。
2.找到需要反编译的代码存放路径。
3.拼写命令,执行。

jad -o -r -sjava -dsrc druid-1.1.10/com/alibaba/druid/**/*.class

参数含义:
-o 无需确认直接覆盖输出
-r 恢复包的目录结构
-sjava 指定输出文件的类型java
-dsrc 指定输出文件的文件目录
**代表多级目录层级
*代表任意文件名

需要注意的是命令后的路径,(druid-1.1.10/com/alibaba/druid/*/.class)是相对地址。

反编译命令.png

执行完成之后大家就可以在当前目录下得到一个src文件夹,反编译出来的代码都在里边了。


值得注意的是jad并不是万能的,以下情况是无法正常的反编译出来的。遇到这些情况就需要使用多种反编译工具综合分析了。

1.包含有内部类,则jad处理构造函数的参数时会出错。
2.不支持zip和jar包。(注:如果使用Eclipse插件,则很容易得到包中的某个类的反编译代码)。
3.当有标签块,嵌套循环中有break/continue,有goto语句的时候,会提示信息“Couldn't fully decompile method <name>”;
当有try-catch-finally语句的时候会提示信息“Couldn't resolve all exception handlers in method <name>”。

  1. Currently Jad ignores the contents of the Line Number Table Attribute and the Source File Attribute。
    5.JAD不能处理继承信息,总是把java.lang.Object作为两个不同类的通用父类,需要的时候做强制转换。
    6.jad对inlined functions处理不好。

二维码.png
上一篇下一篇

猜你喜欢

热点阅读