前段时间打包遇到了一个问题,jar包不能加入到apk包中。从Eclipse中完全可以,一旦放到服务器端进行打包就出现了问题。
使用ant debug -d
得到的信息如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
| [dx] trouble processing:
[dx] bad class file magic (cafebabe) or version (0033.0000)
[dx] ...while parsing com/solo/adsdk/network/a.class
[dx] ...while processing com/solo/adsdk/network/a.class
[dx]
[dx] trouble processing:
[dx] bad class file magic (cafebabe) or version (0033.0000)
[dx] ...while parsing com/solo/adsdk/network/b.class
[dx] ...while processing com/solo/adsdk/network/b.class
[dx]
[dx] trouble processing:
[dx] bad class file magic (cafebabe) or version (0033.0000)
[dx] ...while parsing com/solo/adsdk/network/AdsLoader.class
[dx] ...while processing com/solo/adsdk/network/AdsLoader.class
[dx]
[dx] trouble processing:
[dx] bad class file magic (cafebabe) or version (0033.0000)
[dx] ...while parsing com/solo/adsdk/network/UrlConfig.class
[dx] ...while processing com/solo/adsdk/network/UrlConfig.class
|
相比到这里,原因不言则明,原来是jar包的编译版本比工程编译的版本不一致,真实的情况是前后比后者编译版本高。
经过分析,jar包的编译环境是Java 7, 而工程打包的编译环境是Java 6.
如何解决
解决这个问题也简单,不出如下做法
- 更换成Java 6编译出来的jar包
- 使用java 7 打包工程。
如何得知jar包编译版本
解压jar包
1
| jar fx android-support-v4.jar
|
解压后查看当前目录,会多出一个文件夹,这里是名字为android的文件夹。
查看文件信息
1
2
| 11:52 $ file android/support/v4/net/ConnectivityManagerCompat.class
android/support/v4/net/ConnectivityManagerCompat.class: compiled Java class data, version 49.0 (Java 1.5)
|
查找版本
上面我们得到了version 49.0 (Java 1.5)
,有些情况下我们得到的只有version 49.0
需要查找下面的列表
版本映射
- 45.3 = Java 1.1
- 46 = Java 1.2
- 47 = Java 1.3
- 48 = Java 1.4
- 49 = Java 5
- 50 = Java 6
- 51 = Java 7
- 52 = Java 8
参考文章