Android 3.1.1 - Не удалось разрешить: Lcom/google/android/gms/common/internal/zzbq;

так как я обновился до Android Studio 3.1, мой проект больше не работает. Я искал решение по всему Интернету без положительных результатов. Вот ошибка, которую я получаю в Logcat:

 --------- beginning of crash
04-13 13:33:55.466 12720-12720/? E/AndroidRuntime: FATAL EXCEPTION: main
    Process: woopy.domain.com.woopy, PID: 12720
    java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/android/gms/common/internal/zzbq;
        at com.google.firebase.provider.FirebaseInitProvider.attachInfo(Unknown Source:2)
        at android.app.ActivityThread.installProvider(ActivityThread.java:6239)
        at android.app.ActivityThread.installContentProviders(ActivityThread.java:5805)
        at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5722)
        at android.app.ActivityThread.-wrap1(Unknown Source:0)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1656)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:164)
        at android.app.ActivityThread.main(ActivityThread.java:6494)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
     Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.android.gms.common.internal.zzbq" on path: DexPathList[[zip file "/data/app/woopy.domain.com.woopy-KqNv1gE1ZomaesHCq33DJw==/base.apk"],nativeLibraryDirectories=[/data/app/woopy.domain.com.woopy-KqNv1gE1ZomaesHCq33DJw==/lib/x86, /system/lib, /vendor/lib]]
        at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:125)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
        at com.google.firebase.provider.FirebaseInitProvider.attachInfo(Unknown Source:2) 
        at android.app.ActivityThread.installProvider(ActivityThread.java:6239) 
        at android.app.ActivityThread.installContentProviders(ActivityThread.java:5805) 
        at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5722) 
        at android.app.ActivityThread.-wrap1(Unknown Source:0) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1656) 
        at android.os.Handler.dispatchMessage(Handler.java:106) 
        at android.os.Looper.loop(Looper.java:164) 
        at android.app.ActivityThread.main(ActivityThread.java:6494) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807) 
04-13 13:33:55.567 12720-12727/? I/zygote: Debugger is no longer active

Вот мой файл build.gradle (Module:app):

android {
    compileSdkVersion 27
    buildToolsVersion "27.0.3"
    defaultConfig {
        applicationId "woopy.domain.com.woopy"
        minSdkVersion 21
        targetSdkVersion 27
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"

        // Enabling multidex support.
        multiDexEnabled true

        aaptOptions {
            cruncherEnabled = false
        }

    }


    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }

    dexOptions {
        javaMaxHeapSize "4g"
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'com.squareup.okhttp3:okhttp:3.10.0'
    //noinspection GradleCompatible
    implementation 'com.android.support:appcompat-v7:27.1.1'
    implementation 'com.android.support:support-v4:27.1.1'
    implementation 'com.android.support:design:27.1.1'
    testImplementation 'junit:junit:4.12'
    implementation 'com.parse:parse-android:+'
    implementation 'com.parse.bolts:bolts-android:1.+'
    //noinspection GradleCompatible
    implementation 'com.google.android.gms:play-services-maps:+'
    implementation 'com.google.android.gms:play-services-auth:12.0.1'
    implementation 'com.google.android.gms:play-services-location:12.0.1'
    implementation 'com.google.android.gms:play-services:+'
    implementation 'com.google.android.gms:play-services-ads:+'
    implementation 'de.hdodenhof:circleimageview:2.2.0'
    implementation 'com.facebook.android:facebook-android-sdk:4.+'
    implementation 'com.parse:parsefacebookutils-v4-android:1.10.3@aar'
    implementation 'com.commit451:PhotoView:1.2.4'

}

А вот мой build.gradle (Project: appname):

buildscript {
    repositories {
        jcenter()
        maven { url 'https://maven.google.com' }
        google()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.1.1'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
        maven { url "https://maven.google.com" }
        maven {
            url 'https://maven.google.com/'
            name 'Google'
        }
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

Сборка прошла успешно, но приложение вылетает при запуске.

РЕДАКТИРОВАТЬ: Теперь он не собирается успешно, он выдает эту совершенно странную ошибку в консоли сообщений сборки:

AGPBI: {"kind":"error","text":"Program type already present: com.google.android.gms.location.places.zza","sources":[{}],"tool":"D8"}
:app:transformDexArchiveWithExternalLibsDexMergerForDebug FAILED

FAILURE: Build failed with an exception.

* What went wrong:
Execution failed for task ':app:transformDexArchiveWithExternalLibsDexMergerForDebug'

.


person Frank Eno    schedule 13.04.2018    source источник
comment
Я попытался обновить все игровые сервисы до версии 15.0.0, так как она была выпущена всего несколько дней назад. Но при его использовании я продолжал получать сообщение об ошибке о том, что моя версия сервисов Google Play устарела.   -  person Rob Avery IV    schedule 13.04.2018
comment
да, та же проблема. поэтому единственное решение, которое я нашел до сих пор, - это перейти на AS 3.1.   -  person Frank Eno    schedule 13.04.2018
comment
github.com/evollu/react-native-fcm/issues/998   -  person NehaK    schedule 28.08.2020


Ответы (9)


Попробуйте добавить эту зависимость в ваш файл gradle:

implementation 'com.android.support:multidex:1.0.3'

Также вы должны использовать одни и те же версии для библиотек поддержки и игровых сервисов. И вам следует избегать использования "+" для последней версии. Измените эту часть:

implementation 'com.google.android.gms:play-services-maps:+'
implementation 'com.google.android.gms:play-services-auth:12.0.1'
implementation 'com.google.android.gms:play-services-location:12.0.1'
implementation 'com.google.android.gms:play-services:+'
implementation 'com.google.android.gms:play-services-ads:+'

в это:

implementation 'com.google.android.gms:play-services-maps:12.0.1'
implementation 'com.google.android.gms:play-services-auth:12.0.1'
implementation 'com.google.android.gms:play-services-location:12.0.1'
implementation 'com.google.android.gms:play-services:12.0.1'
implementation 'com.google.android.gms:play-services-ads:12.0.1'

РЕДАКТИРОВАНИЕ: вы также можете добавить эту часть в файл Gradle на уровне приложения и повторить попытку. Я не видел, чтобы кто-то пробовал это, но это может сработать.

allprojects {
    repositories {
       //...
    }

    subprojects {
        project.configurations.all {
            resolutionStrategy.eachDependency { details ->
                if (details.requested.group == 'com.google.android.gms'
                && !details.requested.name.contains('multidex') ) {
                    details.useVersion "12.0.1"
                }
            }
        }
    }
}

ВТОРОЕ ОБНОВЛЕНИЕ: только что увидел это, приведенная ниже зависимость охватывает все остальные, поэтому это может вызвать проблему дублирования. Удалите другие зависимости и оставьте эту:

implementation 'com.google.android.gms:play-services:12.0.1'
person Oğuzhan Döngül    schedule 13.04.2018
comment
без этой строчки не строится, я уже пробовал это вчера :( - person Frank Eno; 14.04.2018
comment
@cubycode вы должны добавлять только то, что вам нужно. Удалите его и добавьте необходимую зависимость, в противном случае вам нужно удалить другие зависимости игровых сервисов. Потому что это включает в себя всех их. - person Oğuzhan Döngül; 14.04.2018
comment
мне нужны карты и местоположение, но оно не строится, если я оставлю их и удалю сервисы+. в любом случае я сделаю некоторые другие тесты - person Frank Eno; 14.04.2018
comment
я пробовал использовать только зависимость от пакетных сервисов и удалил другие игровые сервисы в другом приложении: это сработало, так что большое спасибо за вашу помощь! - person Frank Eno; 14.04.2018

У меня была такая же проблема, и я решил ее. Обновите все ваши зависимости com.google.android.gms:play-services до 15.0.0. Это должно выглядеть так:

implementation 'com.google.android.gms:play-services-maps:15.0.0'
implementation 'com.google.android.gms:play-services-auth:15.0.0'
implementation 'com.google.android.gms:play-services-location:15.0.0'
implementation 'com.google.android.gms:play-services:15.0.0'
implementation 'com.google.android.gms:play-services-ads:15.0.0'

Как только вы это сделаете, это должно решить проблему с поиском ошибки NoClassDefFoundError (по крайней мере, это было для меня).

person Rob Avery IV    schedule 13.04.2018
comment
следующая зависимость охватывает все остальные и может вызвать проблему при сборке проекта: реализация 'com.google.android.gms:play-services:15.0.0', поэтому вы либо удаляете ее, либо удаляете все остальные игровые сервисы. зависимости и оставьте эту (потому что это набор зависимостей всех игровых сервисов) - person Frank Eno; 15.04.2018

Это сработало для меня, я добавил блок подпроектов, как показано ниже, в файл проекта gradle.

allprojects {
repositories {
   //...
}
subprojects {
    project.configurations.all {
        resolutionStrategy.eachDependency { details ->
            if (details.requested.group == 'com.google.android.gms'
                    && !details.requested.name.contains('multidex') ) {
                details.useVersion "+"
            }

            if (details.requested.group == 'com.google.firebase'
                    && !details.requested.name.contains('multidex') ) {
                details.useVersion "+"
            }
        }
    }
}
}
person Daniel Raouf    schedule 27.10.2019

Возможно, вы используете разные версии библиотек.

Важный момент: вы можете использовать внешнюю библиотеку, которая использует другую версию игровых сервисов (может быть старше). Пожалуйста, внимательно проверяйте все обновления внешних библиотек и сопоставляйте их все.

person HarshitG    schedule 03.05.2018

Я решил это, удалив

implementation "com.google.android.gms:play-services:$play_service_version"

и сохраняя только важные зависимости.

В моем случае у меня было

implementation "com.google.android.gms:play-services:$play_service_version"
implementation "com.google.android.gms:play-services-location:$play_service"

И я удалил

implementation "com.google.android.gms:play-services:$play_service_version"

и сохранил

implementation "com.google.android.gms:play-services-location:$play_service"

Здесь play_service_version и play_service версии

person Kishan Solanki    schedule 04.05.2018
comment
Нет, это обратная сторона принятого ответа @cubycode, вам нужно снова прочитать оба ответа - person Kishan Solanki; 05.05.2018

У меня была точно такая же проблема. Я пробовал довольно много вещей, но вот что действительно помогло.

Я добавил это в свой проект: implementation 'com.google.android.gms:play-services-base:16.0.1'.

Ошибка ушла.

Затем я удалил его. Все было по-прежнему хорошо. Почистил проект - ошибки нет.

Не спрашивайте меня о логике этого, это просто сработало для меня, это все, что я знаю.

person zarsky    schedule 17.12.2018

@cubycode Я также сталкиваюсь с той же проблемой, и я пробовал все решения, перечисленные здесь.

person Aniruddh Gogate    schedule 23.04.2018
comment
Важный момент: вы можете использовать внешнюю библиотеку, которая использует другую версию игровых сервисов (может быть старше). Пожалуйста, внимательно проверяйте все обновления внешних библиотек и сопоставляйте их все. - person HarshitG; 03.05.2018

Я получил ту же ошибку даже с 'zzbq;' в конце

В приложении build.gradle мне пришлось обновить com.google.firebase:firebase-core до 16.0.1, чтобы он соответствовал той же строке в файле react-native-firebase build.gradle.

Пример:

приложение/build.gradle

implementation 'com.google.firebase:firebase-core:16.0.1'

реакция-native-firebase/android/build.gradle

compileOnly "com.google.firebase:firebase-core:16.0.1"
person bo_    schedule 11.08.2018

Шаг 1:

Такая ошибка выдает некоторые журналы. Внимательно прочитайте его, чтобы узнать, какая зависимость вызывает эту проблему.

Шаг 2:

Обновите эту зависимость до последней версии.

Например: в моем случае это выдает ошибку в зависимости от дизайна материала. Я просто обновляю эту зависимость до последней версии - проблема решена

Мой журнал ошибок: не найден класс "com.google.android.material.tabs........"

person Ranjith Kumar    schedule 16.05.2020