问题:本地调试运行没有问题,打包后运行闪退。
如果你也遇到这个问题,首先判断一下是否是混淆问题。如果最近集成过第三方SDK,那么就去让他们提供一下混淆规则。
我这个比较坑的是找到第三方,对方说没有混淆规则,然后我只能自己看报错信息解决问题,其实应该很简单,但是自己走了很多弯路,这里记录一下。
报错如下:
2019-09-04 17:12:32.073 4478-4478/? E/zygote: Failed to register native method org.chromiun.base.library_loader.LibraryLoader.nativeRecordChromiumAndroidLinkerBrowserHistogram(ZZIJ)V in /data/app/com.daddad.client-utmpExwPmUn4MQO8sCy1IA==/base.apk!classes3.dex
2019-09-04 17:12:32.074 4478-4478/? E/chromiun: [0904/171232:ERROR:jni_generator_helper.h(28)] RegisterNatives failed in gen/base/base_jni_headers/base/jni/LibraryLoader_jni.h
2019-09-04 17:12:32.080 4478-4478/? E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.aa.client, PID: 4478
java.lang.UnsatisfiedLinkError: JNI_ERR returned from JNI_OnLoad in "/data/app/com.aa.client-utmpExwPmUn4MQO8sCy1IA==/lib/arm/libxwalkcore.so"
at java.lang.Runtime.loadLibrary0(Runtime.java:1016)
at java.lang.System.loadLibrary(System.java:1660)
at com.aa.core.b.b.cp(Unknown Source:10)
at com.aa.core.b.b.init(Unknown Source:171)
at com.aa.eas.eclite.ui.EApplication.onCreate(Unknown Source:30)
at com.kdweibo.android.config.Application.onCreate(Unknown Source:8)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1123)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:6636)
at android.app.ActivityThread.-wrap2(Unknown Source:0)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2084)
at android.os.Handler.dispatchMessage(Handler.java:109)
at android.os.Looper.loop(Looper.java:166)
at android.app.ActivityThread.main(ActivityThread.java:7555)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:469)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:963)
看到报错信息,习惯性的copy出下面的代码,一顿百度,花了一上午时间,最后没有解决问题。
其实重要的报错信息在上面:
提示的比较明显,我这个闪退其实因为三方SDK里面用的native方法,native方法被混淆后是找不到了。所以copy上面小框里的代码,双击shift搜索一下,找到这个类,copy出包名,然后添加到 proguard-rules.pro 文件中。
-keep class com.aa.core.** {*;} (com.aa.core 换成复制的包名)
其实挺简单的过程,自己因为这个功能集成了三个SDK,刚开始只添加了其中一个SDK的包名,没有添加native所在SDK的包名,所以自己一直怀疑这种添加混淆的方式可不可行,导致自己花费了很多时间。