Podążam za Google's documentation dla Google Sign. Mając dziwny problem, gdy zadzwonięGoogle Zaloguj się nie działa
Intent signInIntent = Auth.GoogleSignInApi.getSignInIntent (mGoogleApiClient);
startActivityForResult (signInIntent, RC_SIGN_IN);
Jego wydaje Intent został zwolniony, ale nie widzę konto kompletacji dialogowe. Używam
compile "com.google.android.gms:play-services-auth:9.6.1"
Kiedy sprawdzić czy jest podłączony googleclient przedmiot, to zwraca true.
To działa w niektórych urządzeniach, ale nie na każdym urządzeniu (specjalnie Xiaomi)
Realizacji
@OnClick (R.id.google_singin_button)
void signInButtonClicked() {
HashMap<String, Object> map = new HashMap<>();
map.put (AllAnalytics.LABEL, AllAnalytics.Label.SIGN_IN_GOOGLE);
map.put (AllAnalytics.ACTION, AllAnalytics.Action.CLICK);
map.put (AllAnalytics.CATEGORY, AllAnalytics.Category.REGISTRATION_SCREEN);
aa.analyticsEventOccur (map);
if (null != mGoogleApiClient) {
// Log.e(TAG,mGoogleApiClient.isConnected()+"");
Intent signInIntent = Auth.GoogleSignInApi.getSignInIntent (mGoogleApiClient);
startActivityForResult (signInIntent, RC_SIGN_IN);
}
}
@Override
public void onActivityResult (int requestCode, int resultCode, Intent data) {
super.onActivityResult (requestCode, resultCode, data);
// Result returned from launching the Intent from GoogleSignInApi.getSignInIntent(...);
if(Activity.RESULT_CANCELED != resultCode)
if (requestCode == RC_SIGN_IN) {
GoogleSignInResult result = Auth.GoogleSignInApi.getSignInResultFromIntent (data);
handleSignInResult (result);
}
}
@Override
public void onCreate (Bundle savedInstanceState) {
super.onCreate (savedInstanceState);
mActivity = (RegisterActivity) getActivity();
GoogleSignInOptions gso
= new GoogleSignInOptions.Builder (GoogleSignInOptions.DEFAULT_SIGN_IN)
.requestServerAuthCode (getString (R.string.google_client_auth), false)
.requestEmail()
.build();
mGoogleApiClient = new GoogleApiClient.Builder (getContext())
.enableAutoManage (mActivity , this)
.addApi (Auth.GOOGLE_SIGN_IN_API, gso)
.build();
}
Log Kot
Class not found when unmarshalling: com.google.android.gms.auth.api.signin.internal.SignInConfiguration
java.lang.ClassNotFoundException: com.google.android.gms.auth.api.signin.internal.SignInConfiguration
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:309)
at java.lang.Class.forName(Class.java:273)
at android.os.Parcel.readParcelableCreator(Parcel.java:2281)
at android.os.Parcel.readParcelable(Parcel.java:2245)
at android.os.Parcel.readValue(Parcel.java:2152)
at android.os.Parcel.readArrayMapInternal(Parcel.java:2485)
at android.os.BaseBundle.unparcel(BaseBundle.java:221)
at android.os.BaseBundle.containsKey(BaseBundle.java:269)
at android.content.Intent.hasExtra(Intent.java:4884)
at com.miui.server.XSpaceManagerService.isPublicIntent(XSpaceManagerService.java:174)
at com.android.server.am.ActivityStackSupervisorInjector.checkXSpaceControl(ActivityStackSupervisorInjector.java:56)
at com.android.server.am.ActivityStackSupervisor.startActivityMayWait(ActivityStackSupervisor.java:897)
at com.android.server.am.ActivityManagerService.startActivityAsUser(ActivityManagerService.java:3478)
at com.android.server.am.ActivityManagerService.startActivity(ActivityManagerService.java:3465)
at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:140)
at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2245)
at android.os.Binder.execTransact(Binder.java:446)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.android.gms.auth.api.signin.internal.SignInConfiguration" on path: DexPathList[[directory "."],nativeLibraryDirectories=[/vendor/lib64, /system/lib64]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:309)
at java.lang.Class.forName(Class.java:273)
at android.os.Parcel.readParcelableCreator(Parcel.java:2281)
at android.os.Parcel.readParcelable(Parcel.java:2245)
at android.os.Parcel.readValue(Parcel.java:2152)
at android.os.Parcel.readArrayMapInternal(Parcel.java:2485)
at android.os.BaseBundle.unparcel(BaseBundle.java:221)
at android.os.BaseBundle.containsKey(BaseBundle.java:269)
at android.content.Intent.hasExtra(Intent.java:4884)
at com.miui.server.XSpaceManagerService.isPublicIntent(XSpaceManagerService.java:174)
at com.android.server.am.ActivityStackSupervisorInjector.checkXSpaceControl(ActivityStackSupervisorInjector.java:56)
at com.android.server.am.ActivityStackSupervisor.startActivityMayWait(ActivityStackSupervisor.java:897)
at com.android.server.am.ActivityManagerService.startActivityAsUser(ActivityManagerService.java:3478)
at com.android.server.am.ActivityManagerService.startActivity(ActivityManagerService.java:3465)
at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:140)
at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2245)
at android.os.Binder.execTransact(Binder.java:446)
Suppressed: java.lang.ClassNotFoundException: com.google.android.gms.auth.api.signin.internal.SignInConfiguration
at java.lang.Class.classForName(Native Method)
at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
... 19 more
Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available
10-11 23:46:17.873 1387-4537/? E/JavaBinder: *** Uncaught remote exception! (Exceptions are not yet supported across processes.)
java.lang.RuntimeException: Parcel [email protected]: Unmarshalling unknown type code 6684783 at offset 320
at android.os.Parcel.readValue(Parcel.java:2228)
at android.os.Parcel.readArrayMapInternal(Parcel.java:2485)
at android.os.BaseBundle.unparcel(BaseBundle.java:221)
at android.os.BaseBundle.containsKey(BaseBundle.java:269)
at android.content.Intent.hasExtra(Intent.java:4884)
at com.miui.server.XSpaceManagerService.shouldResolveAgain(XSpaceManagerService.java:145)
at com.android.server.am.ActivityStackSupervisorInjector.resolveXSpaceIntent(ActivityStackSupervisorInjector.java:68)
at com.android.server.am.ActivityStackSupervisor.startActivityMayWait(ActivityStackSupervisor.java:898)
at com.android.server.am.ActivityManagerService.startActivityAsUser(ActivityManagerService.java:3478)
at com.android.server.am.ActivityManagerService.startActivity(ActivityManagerService.java:3465)
at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:140)
at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2245)
at android.os.Binder.execTransact(Binder.java:446)
10-11 23:46:17.873 1387-4537/? A/ActivityManager: Activity Manager Crash
java.lang.RuntimeException: Parcel [email protected]: Unmarshalling unknown type code 6684783 at offset 320
at android.os.Parcel.readValue(Parcel.java:2228)
at android.os.Parcel.readArrayMapInternal(Parcel.java:2485)
at android.os.BaseBundle.unparcel(BaseBundle.java:221)
at android.os.BaseBundle.containsKey(BaseBundle.java:269)
at android.content.Intent.hasExtra(Intent.java:4884)
at com.miui.server.XSpaceManagerService.shouldResolveAgain(XSpaceManagerService.java:145)
at com.android.server.am.ActivityStackSupervisorInjector.resolveXSpaceIntent(ActivityStackSupervisorInjector.java:68)
at com.android.server.am.ActivityStackSupervisor.startActivityMayWait(ActivityStackSupervisor.java:898)
at com.android.server.am.ActivityManagerService.startActivityAsUser(ActivityManagerService.java:3478)
at com.android.server.am.ActivityManagerService.startActivity(ActivityManagerService.java:3465)
at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:140)
at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2245)
at android.os.Binder.execTransact(Binder.java:446)
Użyłem tej samej wersji auth9.6.1 ostatnio działa dobrze. przejrzyj dokumentację logowania google jeszcze raz. – HourGlass
@HourGlass były tam wiele razy. – UMESH0492
możesz udostępnić całą część wdrożenia? – HourGlass