dex2jar 报错 com.googlecode.d2j.DexException: not support version

1. 前言

​ 在日常开发中,有时候想做一点羞羞的事情(ps: 学习一下别人的代码),但是一用dex2jar工具反编就报com.googlecode.d2j.DexException: not support version异常,在我高涨的学习热情上直接浇了一盆冷水。(后面有工具下载地址)

2. 反编手顺:

​ 反编其实很简单,先简单叙述一下:

  • Step 1:将apk用任意解压工具直接解压(我用的zip)得到classes.dex,你可能会得到很多dex,不要紧,一个一个反编就行。

  • Step 2 : 使用dex2jar工具将每一个dex文件反编成jar包

    • 将dex2jar工具解压到任意目录(我暂时解压到桌面)
    • 进入解压目录并且按(shift+右键,选择在此处打开命令行窗口)进入cmd命令行
    • 将classes.dex拷贝到dex2jar工具目录,使用指令:d2j-dex2jar.bat classes.dex 即可得到反编后的jar包
dex2jar正常结果.png
  • Step 3 : 使用JD-GUI工具尽情学习就行了。

3. 问题发现:

​ 使用dex2jar工具反编的时候,一输入指令,结果报com.googlecode.d2j.DexException: not support version错误(如下图)

异常情况.png

4.1 调查原因:

谷歌对dex文件的介绍:常量数组/字符串 DEX_FILE_MAGIC 是字节列表,这类字节必须出现在 .dex 文件的开头,以便系统将其原样识别。该值会特意包含一个换行符("\n"0x0a)和空字节("\0"0x00),以便协助检测某些形式的损坏问题。该值还可以将格式版本号编码为 3 个十进制数字;随着格式的演变,预计该值会单调递增。

注意:Android 9.0 版本中新增了对 039 版格式的支持,其中引入了两个新字节码 const-method-handleconst-method-type。(字节码集合的总结表中介绍了这些字节码。)在 Android 10 中,版本 039 扩展了 DEX 文件格式,以包含仅适用于启动类路径上的 DEX 文件的隐藏 API 信息。

注意:Android 8.0 版本中新增了对 038 版格式的支持。038 版本中添加了新字节码(invoke-polymorphicinvoke-custom)和用于方法句柄的数据。

注意:Android 7.0 版本中新增了对 037 版格式的支持。在 037 版本之前,大多数 Android 版本都使用过 035 版格式。035 版与 037 版之间的唯一区别是,是否添加默认方法以及是否调整 invoke

简单地说:就是Android Studio中配置的minSdkVersion参数对应的系统版本是多少,dex文件头就会是多少

例如:minSdkVersion配置成24(对应7.0的系统),编译出来的dex头为037版本(使用notepad++打开dex文件就可以看到)

android {
    ......
    defaultConfig {
        ......
        minSdkVersion 24
        ......
    }
编译出来的dex文件.png

4.2 根本原因调查:

​ 其实看了调查4.1就已经有方案了,就是修改dex文件中的版本信息就可以。但是不知道根本原因心里不甘心,继续调查。

​ 根据报错信息看:com.googlecode.d2j.reader.DexFileReader.(DexFileReader.java:151)

​ 猜测是reader.DexFileReader的构造方法中报出来的错误,打开dex2jar-2.0\lib目录,将dex-reader-2.0.jar或者dex-reader-api-2.0.jar丢进jd-gui工具中看看源码如下:

// 构造方法中找到报错点
public DexFileReader(ByteBuffer in){
        ......
        int version = in.getInt() & 0xFFFFFF;
        if ((version != 3486512) && (version != 3552048)) {
          throw new DexException("not support version.");
        }
        skip(in, 32);
        ......
    }
    .....
}

// 支持的版本定义
private static final int MAGIC_035 = 3486512;
private static final int MAGIC_036 = 3552048;

意味着dex2jar-2.0工具只支持035和036版本协议!!!

5.解决问题

​ 使用notepad++文件浏览工具(任何能打开文件的工具都可以,例如记事本...)打开dex文件,修改版本信息037为036或者035,然后保存文件即可,再使用反编指令:d2j-dex2jar.bat classes.dex 反编即可成功。

修改dex版本信息后.png
正常获得jar包.png

6.参考文档:

谷歌对dex文件的介绍

反编译工具下载传送门

你可能感兴趣的:(dex2jar 报错 com.googlecode.d2j.DexException: not support version)