7

Nella nuova libreria di Google Play Services (8.3.0) è disponibile un nuovo modo per eseguire l'accesso. Questo metodo comporta l'aggiunta le seguenti dipendenze:Problemi di offuscamento Proguard dopo l'aggiunta di nuovo Google Accedi all'applicazione Android

build.gradle (livello applicazione): classpath 'com.google.gms:google-services:1.4.0-beta3'

E a livello di app:

compile 'com.google.android.gms:play-services-auth:8.3.0' 

`apply plugin: 'com.google.gms.google-services'` 

Quando si crea una versione app con minifyEnabled insieme a false, l'app è stata rilasciata e funziona perfettamente. Tuttavia, quando si crea una versione con minifyEnabled impostato su true l'applicazione si blocca all'avvio con la seguente eccezione:

java.lang.RuntimeException: Unable to get provider com.google.android.gms.measurement.AppMeasurementContentProvider: java.lang.ClassNotFoundException: Didn't find class "com.google.android.gms.measurement.AppMeasurementContentProvider" on path: DexPathList[[zip file "/data/app/com.xxx.xxx-1/base.apk"],nativeLibraryDirectories=[/data/app/com.xxx.xxx-1/lib/arm, /vendor/lib, /system/lib]] 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at android.app.ActivityThread.installProvider(ActivityThread.java:5156) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at android.app.ActivityThread.installContentProviders(ActivityThread.java:4748) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4688) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at android.app.ActivityThread.-wrap1(ActivityThread.java) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1405) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at android.os.Handler.dispatchMessage(Handler.java:102) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at android.os.Looper.loop(Looper.java:148) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at android.app.ActivityThread.main(ActivityThread.java:5417) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at java.lang.reflect.Method.invoke(Native Method) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime:  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 
11-08 12:47:13.497 3672-3672/? E/AndroidRuntime: Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.android.gms.measurement.AppMeasurementContentProvider" on path: DexPathList[[zip file "/data/app/xxx.xxx... 

ho cercato di aggiungere queste impostazioni per la configurazione del progetto Proguard ma non aiuta (stesso continua ad apparire):

-optimizationpasses 5 
-keepattributes SourceFile,LineNumberTable,Exceptions, Signature, InnerClasses,*Annotation* 
-keep class com.google.android.gms.** { *; } 
-dontwarn com.google.android.gms.** 
+0

Probabilmente è necessario aggiungere anche '-keepattributes Exceptions, Signature, InnerClasses'. – ztan

+0

Purtroppo questo non aiuta, ho modificato la domanda per mostrare le parti (rilevanti) della proguard. – Peter

+0

potenzialmente un bug, puoi archiviare il tracker di problemi pubblici Android https://code.google.com/p/android/issues/list – ztan

risposta

0

Ho già archiviato uno bug report for this.

+3

Grazie, suppongo che la correzione per questo bug report sia stata implementata nella versione 1.5. 0 del plug-in per i servizi di google. L'aggiunta di questa dipendenza ha risolto il problema per me: classpath 'com.google.gms: google-services: 1.5.0' – Peter

+1

@Peter, grazie che ha aiutato – artman

+0

@Peter grazie, questo ha risolto il problema. –