目录
一.问题发现
二.调查原因:
三. 根本原因调查:
四.解决问题
一.问题发现
使用dex2jar工具反编的时候,一输入指令,结果报com.googlecode.d2j.DexException: not support version错误(如下图)
异常情况.png
二.调查原因:
谷歌对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文件就可以看到)
android {
......
defaultConfig {
......
minSdkVersion 24
......
}
编译出来的dex文件.png
三. 根本原因调查:
其实看了调查三就已经有方案了,就是修改dex文件中的版本信息就可以。但是不知道根本原因心里不甘心,继续调查。
根据报错信息看:com.googlecode.d2j.reader.DexFileReader.<init>(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版本协议!!!
四.解决问题
使用notepad++文件浏览工具(任何能打开文件的工具都可以,例如记事本...)打开dex文件,修改版本信息037为036或者035,然后保存文件即可,再使用反编指令:d2j-dex2jar.bat classes.dex 反编即可成功。
修改dex版本信息后.png
正常获得jar包.png