Я получаю это сообщение об ошибке при попытке реализовать выход из системы для входа в Google для Android:
Caused by: java.lang.IllegalStateException: GoogleApiClient is not connected yet.
Сбой происходит в DrawerActivity.java (ниже), где я вызываю метод signOut().
Я просмотрел решения в других сообщениях и пробовал их безрезультатно:
java.lang.IllegalStateException: GoogleApiClient еще не подключен
Исключение GoogleApiClient еще не подключено Неустранимая ошибка: java.lang.IllegalStateException GoogleApiClient еще не подключен
Основная активность.java:
protected void onCreate(Bundle savedInstanceState) {
mGoogleApiClient = new GoogleApiClient.Builder(this)
.enableAutoManage(this, this)
.addApi(Auth.GOOGLE_SIGN_IN_API, gso)
.build();
//... other code for google sign in not shown
}
protected void onStart() {
mGoogleApiClient.connect();
}
private void handleSignInResult(GoogleSignInResult result) {
if (result.isSuccess()) {
App.getInstance().setClient(mGoogleApiClient);
//start DrawerActivity
}
}
В DrawerActivity.java (где я хочу выполнить выход)
private void googleSignOut(){
mGoogleApiClient = App.getInstance().getClient();
Auth.GoogleSignInApi.signOut(mGoogleApiClient);
}
В моем приложении, которое расширяет приложение (используется для хранения GoogleApiClient)
public class App extends Application {
private GoogleApiClient mGoogleApiClient;
private static App mInstance;
@Override
public void onCreate() {
super.onCreate();
mInstance = this;
}
public static synchronized App getInstance() {
return mInstance;
}
public void setClient(GoogleApiClient client){
mGoogleApiClient = client;
}
public GoogleApiClient getClient(){
return mGoogleApiClient;
}
}
Трассировки стека:
21:33.314 25375-25375/com.me.myapp E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.me.myapp, PID: 25375
java.lang.IllegalStateException: GoogleApiClient is not connected yet.
at com.google.android.gms.internal.zzmf.zzb(Unknown Source)
at com.google.android.gms.internal.zzmi.zzb(Unknown Source)
at com.google.android.gms.internal.zzmg.zzb(Unknown Source)
at com.google.android.gms.auth.api.signin.internal.zzc.signOut(Unknown Source)
at com.me.myapp.DrawerActivity.googleSignOut(DrawerActivity.java:526)
at com.me.myapp.DrawerActivity.onNavigationDrawerItemSelected(DrawerActivity.java:512)
at com.me.myapp.NavigationDrawerFragment.selectItem(NavigationDrawerFragment.java:201)
at com.me.myapp.NavigationDrawerFragment.access$000(NavigationDrawerFragment.java:31)
at com.me.myapp.NavigationDrawerFragment$1.onItemClick(NavigationDrawerFragment.java:98)
at android.widget.AdapterView.performItemClick(AdapterView.java:310)
at android.widget.AbsListView.performItemClick(AbsListView.java:1145)
at android.widget.AbsListView$PerformClick.run(AbsListView.java:3042)
at android.widget.AbsListView$3.run(AbsListView.java:3879)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteI
Любая помощь будет оценена по достоинству. Спасибо!
mGoogleApiClient.connect()
в onStart ();, но это не имеет никакого эффекта. Я получаю такое же сообщение о сбое. Я также вызвал .connect() в методе signOut(), все еще то же самое сообщение о сбое. - person VIN   schedule 08.03.2016#handleSignInResult
. Этот метод может вызываться с неудачным результатом, что означает, что#setClient
никогда не вызывается. - person Scott Tomaszewski   schedule 08.03.2016result.isSuccess()
оценивается как true, поэтому на самом деле вызываетсяApp.getInstance().setClient(mGoogleApiClient);
. - person VIN   schedule 08.03.2016GoogleApiClient
. Согласно этому сообщению (stackoverflow.com/a/25190497/608347), клиент не является тяжелым объектом, поэтому может Избегайте запутанного дизайна и делайте все просто. Даже если вы не пойдете по этому пути, вы должны удалить этот код#setClient
и#getClient
и посмотреть, получите ли вы ту же ошибку при отключении от одного действия. - person Scott Tomaszewski   schedule 08.03.2016