一次被迫的升级
最近抽时间维护我的应用《知豆了2》,进行了一些Bug的修复,框架的升级以及新加了喷嚏图卦这个栏目,功能更新的差不多了,想提交到应用市场上更新以下版本,结果提交给小米后,出现了一个问题就是,我的应用被安天杀毒引擎查出有病毒.....
第一反应就是,肯定是引入的第三方包有问题了,于是想了想项目中主要用到了两个第三方功能包,第一个是ShareSDK,另一个是Bmob,直觉告诉我,应该是Bmob出了问题,然后百度之,果然:
我的Bmob是很老的版本了,因为一直能用,也没想过要升级,谁知今天被它坑了,赶紧着手升级吧,看了下升级文档,Bmob现在高大上了,之前只能通过引入Jar包和SO库的方式进行集成,现在也升级到可以直接使用Gradle依赖进行集成了,方便了很多啊,于是立即决定使用新的集成方式,把项目中之前引入的Jar包和SO库逐个删除后,郑重的在我的主业务Moudle里加入了这条依赖:
api 'cn.bmob.android:bmob-sdk:3.6.6'
谁知这才是问题的开始.......
初见Unable to merge dex
改了Gradle必然要编译,于是随手点了Sync后就去打水上厕所了,美滋滋的回来后发现,纳尼?一片血红色在我的Build栏目下,仔细一看:
Caused by: com.android.dex.DexException: Multiple dex files define Lcom/google/gson/internal/bind/TypeAdapters;
at com.android.dx.merge.DexMerger.readSortableTypes(DexMerger.java:661)
at com.android.dx.merge.DexMerger.getSortedTypes(DexMerger.java:616)
at com.android.dx.merge.DexMerger.mergeClassDefs(DexMerger.java:598)
at com.android.dx.merge.DexMerger.mergeDexes(DexMerger.java:171)
at com.android.dx.merge.DexMerger.merge(DexMerger.java:198)
at com.android.builder.dexing.DexArchiveMergerCallable.call(DexArchiveMergerCallable.java:61)
... 1 more
* Get more help at https://help.gradle.org
BUILD FAILED in 10s
81 actionable tasks: 8 executed, 73 up-to-date
报错信息超级长,其实关键的节点在最后面,我这边为了篇幅起见,建议您直接看519行,也就是:
Caused by: com.android.dex.DexException: Multiple dex files define Lcom/google/gson/internal/bind/TypeAdapters;
这里的意思就是说,重复的dex文件出现在了TypeAdapters这个类了,然后就利用AndroidStudio的强大的查询功能,双击Shift来搜索TypeAdapters这个关键字,如图(我把自己的图弄丢了,大概就是这个意思 ):
可以看到,这个类在com.google.code.gson和cn.bmob.android这两个Gradle的依赖里都出现了,这就是所谓的重复依赖或者依赖冲突或者Jar包冲突了,其实就是Bmob的SDK里已经自己集成了gson和okio这两个jar了,而我自己在项目中也用到了这两个jar包,从而导致了依赖冲突。
解决方案
既然找到冲突了,那就说一下解决方案吧:
除了删除冲突包外,我们还可以用Gradle的 exclude group 将指定的包名排除到编译范围外:
//bmob-sdk:Bmob的android sdk包,包含了Bmob的数据存储、文件等服务,以下是最新的bmob-sdk:
implementation ('cn.bmob.android:bmob-sdk:3.5.5'){ // gson-2.6.2
exclude group: 'com.squareup.okhttp3'
exclude group: 'com.squareup.okio'
exclude group: 'com.google.code.gson'
// exclude(module: 'gson') // 防止版本冲突
}
至此,冲突解决。