Android - 当 minifyEnabled true 导致 java.lang.ExceptionInInitializerError 时,带有混淆 AAR 库的应用程序崩溃

Posted

技术标签:

【中文标题】Android - 当 minifyEnabled true 导致 java.lang.ExceptionInInitializerError 时,带有混淆 AAR 库的应用程序崩溃【英文标题】:Android - App with obfuscated AAR library is crashing when minifyEnabled true causes java.lang.ExceptionInInitializerError 【发布时间】:2021-08-04 14:24:08 【问题描述】:

我有一个使用 CSRMesh 库作为 AAR 模块的 android 应用程序。 AAR 本身是模糊的。当minifyEnabledbuild.gradle 中为 false 时,我的应用程序运行良好,但当我将其设置为 true 时,应用程序崩溃了。

以下代码来自自定义 MeshLibraryManager 类,用于对库进行 API 调用。

private void enableBluetooth() 
    try 
        mCurrentChannel = MeshChannel.BLUETOOTH;
        isChannelReady = false;
        mBtBearer = new BluetoothBearer(this, mContext.get());
        if (mService != null) 
            mService.setBearer(mBtBearer);  // crash occurs in this line
            mService.setBluetoothBearerEnabled(mBtBearer);
        
        EventBus.getDefault().post(new MeshSystemEvent(MeshSystemEvent.SystemEvent.CHANNEL_NOT_READY));
     catch (Exception e) 
        e.printStackTrace();
    

在此代码块中,mService 是库中 MeshService 类的一个实例。 我在应用程序崩溃的行中添加了一条评论。如果我注释掉该行及其下方的行,应用程序不会崩溃,但我无法执行所需的蓝牙操作。

这是崩溃的完整堆栈跟踪:

2021-05-14 16:21:48.994 27372-27372/com.example.myApp E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.example.myApp, PID: 27372
    java.lang.ExceptionInInitializerError
        at com.csr.internal.mesh_le.g0.a(SourceFile:70)
        at com.csr.internal.mesh_le.f.l(SourceFile:269)
        at com.csr.csrmesh2.MeshService.y(SourceFile:309)
        at com.example.scanner.api.MeshLibraryManager.v(SourceFile:336)
        at com.example.scanner.api.MeshLibraryManager.o(SourceFile:59)
        at com.example.scanner.api.MeshLibraryManager$b.onServiceConnected(SourceFile:595)
        at android.app.LoadedApk$ServiceDispatcher.doConnected(LoadedApk.java:1738)
        at android.app.LoadedApk$ServiceDispatcher$RunConnection.run(LoadedApk.java:1770)
        at android.os.Handler.handleCallback(Handler.java:873)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:201)
        at android.app.ActivityThread.main(ActivityThread.java:6820)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:547)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:922)
    

我已经尝试为所需的类添加 proguard 规则,无论我可以从代码和堆栈跟踪中找到什么,但没有任何效果。

请建议我该如何解决这个问题。

【问题讨论】:

【参考方案1】:

您必须确保以下行将出现在您的 proguard 规则中。这将告诉您的应用程序确保可以使用 SpongyCastle 加密库。

-keep class org.spongycastle.jcajce.provider.asymmetric.**  *; 

【讨论】:

以上是关于Android - 当 minifyEnabled true 导致 java.lang.ExceptionInInitializerError 时,带有混淆 AAR 库的应用程序崩溃的主要内容,如果未能解决你的问题,请参考以下文章

Android 9 崩溃 minifyEnabled 和 multiDexEnabled

Android 因 minifyEnabled 和 AWS 调用而崩溃

Android minifyEnabled true for firebase

Android Gradle 插件BuildType 编译类型配置 ④ ( minifyEnabled 配置 | multiDexEnabled | pseudoLocalesEnabled )

坑:Android Studio gradle minifyEnabled 为 true debug断点失效

坑:Android Studio gradle minifyEnabled 为 true debug断点失效