前言
随着厂里的业务越来越多,需求也越来越多,导致开发的项目也会随之变大。因我厂的项目是类似于电商这种的,前段时间项目有个新需求,加移动客服功能(类似淘宝客服)。在网上找到一些第三方平台,如环信,融云都是不错的选择。结合开发者的比较,最后选定了环信作为这次需求的主力军。一星期后需求按计划完成,也按时上线给客户使用。 但是刚上线不久,工作群中很多客户反应不能安装,这可是个很严重的问题。当时我很纳闷,但奇怪的是也没有Bug Reporter,而且开发过程中也一直没问题,测试那边也是通过的。根据上报的几个用户的机型,我初步推断都是5.0以下的设备无法启动App,通过优测和云测的真机模拟打印出Log后得出判断,错误异常居然是这个:
java.lang.NoClassDefFoundError:
09-30 15:21:59.889 17700-17700/?E/AndroidRuntime: FATAL EXCEPTION: main
Process: your package,PID: 17700
java.lang.NoClassDefFoundError: com.easemob.chat.EMChatConfig
at com.easemob.chat.EMChat.setAppkey(Unknown Source)
at com.easemob.chat.KefuChat.setAppkey(KefuChat.java:126)
at your package.UI.config.BayeApp.initEMChat(BayeApp.java:98)
at your package.UI.config.BayeApp.onCreate(BayeApp.java:51)
atandroid.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1007)
atandroid.app.ActivityThread.handleBindApplication(ActivityThread.java:4440)
at android.app.ActivityThread.access$1500(ActivityThread.java:141)
atandroid.app.ActivityThread$H.handleMessage(ActivityThread.java:1272)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5113)
at java.lang.reflect.Method.invokeNative(Native Method)
atjava.lang.reflect.Method.invoke(Method.java:515)
atcom.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
atcom.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)
at dalvik.system.NativeStart.main(Native Method)
折腾了我好久,因为Log打印的是某个类没有找到,开始以为是该类的代码问题,仔细检查后发现根本不应该是这个类引发的问题。而分别打的两个正式包(5.0以上的手以,和5.0以下的手机)设备报错都不是同一个类。刚开始Google的时候,关键字是NoClassDefFoundError Android,StackoverFlow上网友遇到的是Eclipse的路径配置问题,和我遇到的不是同一个Bug,还有就是导入第三方依赖module,的时候出现的问题。我反反复复检查好好几遍,也按官方的文档配制还是没有解决。为此我还特意的的去请教了第三方的技术之持,但是他们直接说你不是我们正式用户有问题自行解决,就在希望快崩溃的时候,再次Google NoClassDefFoundError Android Studio发现该问题描述和我遇到的一模一样,回想在起平安科技时遇到过Configure Apps with Over 64K Methods该问题,检查后发现Application并没继承MultiDexApplication。
解决方法:
一、配置build.gradle (app)
android {
compileSdkVersion 22
buildToolsVersion "23.3.0"
defaultConfig {
minSdkVersion 15
targetSdkVersion 22
// Enabling multidex support. 开关
multiDexEnabled true
}
dependencies {
// 添加依赖
compile 'com.android.support:multidex:1.0.0'
}
二、使用自定义的Application继承MultiDexApplication这个类,或者重写Application的方法attachBaseContext(),并调用MultiDex.install();
@Override
protected voidattachBaseContext(Context base) {
super.attachBaseContext(base);
MultiDex.install(base);
}
三、到项目的根目录下执行 ./gradlew clean build
总结:
随着互联网发展的越来越快,公司迭代项目也会越来越快,用到第三方的框架也越来越多。因此,遇到的问题也会各种奇葩。Android 5.0以下出现 java.lang.NoClassDefFoundError:这个问题纠结了我快两天,试了各种方法,也请教了朋友。在此把它分享出来,希望在开发的过程中有遇到如此情况的朋友给予帮助。