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包
- Step 3 : 使用JD-GUI工具尽情学习就行了。
3. 问题发现:
使用dex2jar工具反编的时候,一输入指令,结果报com.googlecode.d2j.DexException: not support version错误(如下图)
4.1 调查原因:
谷歌对dex文件的介绍:常量数组/字符串
DEX_FILE_MAGIC
是字节列表,这类字节必须出现在.dex
文件的开头,以便系统将其原样识别。该值会特意包含一个换行符("\n"
或0x0a
)和空字节("\0"
或0x00
),以便协助检测某些形式的损坏问题。该值还可以将格式版本号编码为 3 个十进制数字;随着格式的演变,预计该值会单调递增。注意:Android 9.0 版本中新增了对
039
版格式的支持,其中引入了两个新字节码const-method-handle
和const-method-type
。(字节码集合的总结表中介绍了这些字节码。)在 Android 10 中,版本039
扩展了 DEX 文件格式,以包含仅适用于启动类路径上的 DEX 文件的隐藏 API 信息。注意:Android 8.0 版本中新增了对
038
版格式的支持。038
版本中添加了新字节码(invoke-polymorphic
和invoke-custom
)和用于方法句柄的数据。注意:Android 7.0 版本中新增了对
037
版格式的支持。在037
版本之前,大多数 Android 版本都使用过035
版格式。035
版与037
版之间的唯一区别是,是否添加默认方法以及是否调整invoke
。
简单地说:就是Android Studio中配置的minSdkVersion参数对应的系统版本是多少,dex文件头就会是多少
例如:minSdkVersion配置成24(对应7.0的系统),编译出来的dex头为037版本(使用notepad++打开dex文件就可以看到)
1 | android { |
4.2 根本原因调查:
其实看了调查4.1就已经有方案了,就是修改dex文件中的版本信息就可以。但是不知道根本原因心里不甘心,继续调查。
根据报错信息看:com.googlecode.d2j.reader.DexFileReader.
猜测是reader.DexFileReader
的构造方法中报出来的错误,打开dex2jar-2.0\lib目录,将**dex-reader-2.0.jar
或者dex-reader-api-2.0.jar
**丢进jd-gui工具中看看源码如下:
1 | // 构造方法中找到报错点 |
意味着dex2jar-2.0工具只支持035和036版本协议!!!
5.解决问题
使用notepad++文件浏览工具(任何能打开文件的工具都可以,例如记事本…)打开dex文件,修改版本信息037为036或者035,然后保存文件即可,再使用反编指令:d2j-dex2jar.bat classes.dex 反编即可成功。