web-dev-qa-db-fra.com

Android 3.1.1 - Echec de la résolution de: Lcom/google/Android/gms/commun/interne/zzbq

depuis que j'ai mis à jour Android Studio 3.1, mon projet ne fonctionne plus. J'ai cherché une solution sur Internet sans aucun résultat positif ... Voici l'erreur que j'ai dans le 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

Voici mon fichier 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'

}

Et voici mon 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
}

La construction a réussi, mais l'application se bloque au démarrage.

EDIT: Il ne construit plus avec succès maintenant, il jette cette erreur absolument étrange dans la console de message de construction:

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'

.

10
xscoder

Essayez d’ajouter cette dépendance à votre fichier Gradle:

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

Vous devez également utiliser les mêmes versions pour les bibliothèques de services de support et de lecture. Et vous devriez éviter d'utiliser "+" pour la dernière version. Changer cette partie:

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:+'

dans ceci:

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'

EDIT: Vous pouvez également ajouter cette partie à votre fichier de gradation de niveau d'application et réessayer. Je n'ai vu personne essayer mais cela peut marcher.

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"
                }
            }
        }
    }
}

2ND UPDATE: Je viens de voir ceci, la dépendance ci-dessous couvre tous les autres, cela peut alors causer un problème de duplication. Supprimez les autres dépendances et laissez celle-ci:

implementation 'com.google.Android.gms:play-services:12.0.1'
13
Oğuzhan Döngül

J'ai eu le même problème et je l'ai résolu. Mettez à jour toutes vos dépendances com.google.Android.gms:play-services en 15.0.0. Ça devrait ressembler à ça:

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'

Une fois que vous avez fait cela, cela devrait résoudre le problème de trouver l'erreur NoClassDefFoundError (du moins c'est ce qui m'est arrivé).

5
Rob Avery IV
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'

This helped me.
1
RakeshKB

J'ai eu exactement le même problème. J'ai essayé pas mal de choses, mais voici ce qui a réellement aidé.

J'ai ajouté ceci à mon projet: implementation 'com.google.Android.gms:play-services-base:16.0.1'.

L'erreur est partie.

Puis je l'ai enlevé. Tout allait encore bien. Nettoyé le projet - toujours pas d'erreur.

Ne me demandez pas de logique derrière tout ça, ça a juste fonctionné pour moi, c'est tout ce que je sais.

0
zarsky

J'ai reçu la même erreur même avec le 'zzbq;' à la fin

Dans l'application build.gradle, je devais mettre à jour mon com.google.firebase: firebase-core vers 16.0.1 pour qu'il corresponde à la même ligne dans le build.gradle de react-native-firebase

Exemple:

app/build.gradle

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

react-native-firebase/Android/build.gradle

compileOnly "com.google.firebase:firebase-core:16.0.1"
0
bo_

Vous utilisez peut-être différentes versions de bibliothèques. 

Le point important est que vous utilisez peut-être une bibliothèque externe qui utilise une version différente des services de lecture (peut-être plus ancienne). Veuillez vérifier soigneusement toutes les mises à jour des bibliothèques externes et les faire correspondre à toutes.

0
HarshitG

@cubycode Je rencontre également le même problème et j'ai essayé toutes les solutions énumérées ici.

0
Aniruddh Gogate

Je l'ai résolu en enlevant 

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

et ne garder que les dépendances importantes.

Dans mon cas j'avais

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

Et j'ai enlevé 

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

et gardé 

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

Ici play_service_version et play_service sont des versions

0