Android AAR NoClassDefFoundError

Android AAR NoClassDefFoundError

我正在尝试开源我创建的 a library,但是当我尝试在 Gradle 构建的 APK 下使用库时遇到生成的 AAR 和 NoClassDefFoundErrors 的问题.值得注意的是,如果我将 AAR 转换为旧的、非官方的、现在已弃用的 apklib 格式(并在 android-maven-plugin 构建的 APK 下使用),该库可以正常工作。

有了这些证据,我很可能发现 android-gradle-plugin 缺陷。从尝试所有 documented roots 包括依赖本地 Maven 存储库(包括 AAR)和使用 Studio 的模块导入机制导入 AAR,错误仍然存​​在。

更深入的调查表明并非所有图书馆的 类 都遇到下面提到的问题。具体来说,那些本身依赖 Google 播放服务或 Android 支持库的 类 存在问题。早在 2 月份 就注意到了一个类似的问题(实际上可能完全相同)。

我看到的例外情况如下;

04-21 00:02:25.863  21336-21336/com.oceanlife E/AndroidRuntime﹕ FATAL EXCEPTION: main
    Process: com.oceanlife, PID: 21336
    java.lang.NoClassDefFoundError: com.brantapps.polaris.google.GoogleMapWrapper
            at com.brantapps.polaris.PolarisModule.provideMappable(PolarisModule.java:46)
            at com.brantapps.polaris.PolarisModule$$ModuleAdapter$ProvideMappableProvidesAdapter.get(PolarisModule$$ModuleAdapter.java:57)
            at com.brantapps.polaris.PolarisModule$$ModuleAdapter$ProvideMappableProvidesAdapter.get(PolarisModule$$ModuleAdapter.java:41)
            at com.oceanlife.fragment.addspot.AddSpotMapFragment.onCreate(AddSpotMapFragment.java:171)
            at android.support.v4.app.Fragment.performCreate(Fragment.java:1763)
            at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:915)
            at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1136)
            at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:739)
            at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1499)
            at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:548)
            at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1220)
            at android.app.Activity.performStart(Activity.java:5949)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2261)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
            at android.app.ActivityThread.access0(ActivityThread.java:144)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5221)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)

可以在 GitHub repo here 下查看项目的配置,但为了清楚起见,这里是构建依赖项;

dependencies {
    compile 'com.android.support:support-v4:22.0.0'
    compile 'com.google.guava:guava:18.0'
    compile 'com.squareup.dagger:dagger:1.2.1'

    googleCompile 'com.google.android.gms:play-services:7.0.0'

    kindleCompile 'org.osmdroid:osmdroid-android:4.1'
    kindleCompile 'org.osmdroid:osmbonuspack:4.4'
    kindleCompile 'org.slf4j:slf4j-android:1.7.7'

    provided 'com.squareup.dagger:dagger-compiler:1.2.+'
}

对此问题的任何 insight/workarounds 都非常欢迎。

我发现,如果我在主应用程序中重复导致 NoDefFoundError(如链接的 SO 中所述)的依赖项,那么问题就会消失...

似乎库 AAR 是在没有 Google PlaySupport Library 依赖项的情况下构建的。我相信我可以正确构建它并通过在我的本地 Maven 存储库中生成一个位于 AAR 旁边的适当 pom.xml 来强制解决依赖关系。

这里是我的项目配置供参考;

Android工作室:

--App
  -- build.gradle (repeat dependencies of Polaris)
--Polaris
  -- build.gradle (Google Play and Support dependencies)
--ApiClient
  -- build.gradle (just another module)

本地专家:

--.m2
  -- com
    -- brantapps
      -- polaris-google
        -- 1.0.0
          -- polaris-google-1.0.0.aar
          -- polaris-google-1.0.0.pom (need to build one of these maybe!)