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.**
Probabilmente è necessario aggiungere anche '-keepattributes Exceptions, Signature, InnerClasses'. – ztan
Purtroppo questo non aiuta, ho modificato la domanda per mostrare le parti (rilevanti) della proguard. – Peter
potenzialmente un bug, puoi archiviare il tracker di problemi pubblici Android https://code.google.com/p/android/issues/list – ztan