Утечка окна в диалоге Facebook в Android

Я использую Facebook SDK в своем приложении. Мое требование - поддерживать сессию Facebook для разных пользователей. У меня есть все имя пользователя в базе данных sqlite. Я использовал следующий код, чтобы проверить, вошел ли пользователь в Facebook. Если это первый раз, я отобразил диалоговое окно Facebook и получил токен доступа, и сохранил его в db для конкретного пользователя, а также аннулировал сеанс этого пользователя. Проблема возникает, когда второй пользователь пытается войти в Facebook. Когда появляется диалог входа в систему, он показывает ошибку просочившегося окна в журнале cat.

db = Stats.this.openOrCreateDatabase(DB_NAME,
                    MODE_PRIVATE, null);

            Cursor cur = db.rawQuery("SELECT * FROM " + USER_TABLE_NAME, null);
            if (cur != null) {
                if (cur.moveToFirst()) {
                    do {
                        String reader_name = cur.getString(cur
                                .getColumnIndex("username"));
                        Log.v("reader_name", reader_name);
                        if (reader_name.equals(reader_name_db)) {
                            if (cur.getString(cur.getColumnIndex("fb_token"))
                                    .equals("0")) {
                                authenticatedFacebook.authorize(Stats.this,
                                        PERMISSIONS, -1,
                                        new TestLoginListener());

                            } else {
                                accesstoken = cur.getString(cur
                                        .getColumnIndex("fb_token"));
                                Log.v("AccessToken", accesstoken);
                            }
                        }

                    } while (cur.moveToNext());
                }
            }
            cur.close();
            db.close();

            if (!accesstoken.equals("0")) {
                Toast.makeText(Stats.this, "Access token already present",
                        Toast.LENGTH_LONG).show();
                shareThroughFB();
            }

public class TestLoginListener implements DialogListener {

        public void onComplete(Bundle values) {
            // TODO Auto-generated method stub
            if (authenticatedFacebook.isSessionValid()) {
                accesstoken = authenticatedFacebook.getAccessToken();
                Log.v("AccessToken", accesstoken);
                db = Stats.this.openOrCreateDatabase(REDOMETER_DB_NAME,
                        MODE_PRIVATE, null);

                db.execSQL("update " + USER_TABLE_NAME + " set fb_token='"
                        + accesstoken + "' where username='" + reader_name_db
                        + "'");
                db.close();

    FbDialog.mSpinner.dismiss();
                fb_Logout();


                shareThroughFB();

            }
        }

        public void onFacebookError(FacebookError e) {
            // TODO Auto-generated method stub

        }

        public void onError(DialogError e) {
            // TODO Auto-generated method stub

        }

        public void onCancel() {
            // TODO Auto-generated method stub

        }

    }

Это показывает следующую ошибку.

 10-29 08:41:55.500: E/WindowManager(16738): Activity com.readometer.ReadometerTab has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{42b4e270 V.E..... R.....I. 0,0-1080,1920} that was originally added here
10-29 08:41:55.500: E/WindowManager(16738): android.view.WindowLeaked: Activity com.readometer.ReadometerTab has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{42b4e270 V.E..... R.....I. 0,0-1080,1920} that was originally added here
10-29 08:41:55.500: E/WindowManager(16738):     at android.view.ViewRootImpl.<init>(ViewRootImpl.java:426)
10-29 08:41:55.500: E/WindowManager(16738):     at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:235)
10-29 08:41:55.500: E/WindowManager(16738):     at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:69)
10-29 08:41:55.500: E/WindowManager(16738):     at android.app.Dialog.show(Dialog.java:282)
10-29 08:41:55.500: E/WindowManager(16738):     at com.facebook.android.Facebook.dialog(Facebook.java:628)
10-29 08:41:55.500: E/WindowManager(16738):     at com.facebook.android.Facebook.startDialogAuth(Facebook.java:297)
10-29 08:41:55.500: E/WindowManager(16738):     at com.facebook.android.Facebook.authorize(Facebook.java:195)
10-29 08:41:55.500: E/WindowManager(16738):     at com.readometer.Stats.onClick(Stats.java:596)
10-29 08:41:55.500: E/WindowManager(16738):     at android.view.View.performClick(View.java:4354)
10-29 08:41:55.500: E/WindowManager(16738):     at android.view.View$PerformClick.run(View.java:17961)
10-29 08:41:55.500: E/WindowManager(16738):     at android.os.Handler.handleCallback(Handler.java:725)
10-29 08:41:55.500: E/WindowManager(16738):     at android.os.Handler.dispatchMessage(Handler.java:92)
10-29 08:41:55.500: E/WindowManager(16738):     at android.os.Looper.loop(Looper.java:137)
10-29 08:41:55.500: E/WindowManager(16738):     at android.app.ActivityThread.main(ActivityThread.java:5328)
10-29 08:41:55.500: E/WindowManager(16738):     at java.lang.reflect.Method.invokeNative(Native Method)
10-29 08:41:55.500: E/WindowManager(16738):     at java.lang.reflect.Method.invoke(Method.java:511)
10-29 08:41:55.500: E/WindowManager(16738):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
10-29 08:41:55.500: E/WindowManager(16738):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
10-29 08:41:55.500: E/WindowManager(16738):     at dalvik.system.NativeStart.main(Native Method)
10-29 08:41:55.510: E/WindowManager(16738): Activity com.readometer.ReadometerTab has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{42b592d8 V.E..... R.....ID 0,0-502,346} that was originally added here
10-29 08:41:55.510: E/WindowManager(16738): android.view.WindowLeaked: Activity com.readometer.ReadometerTab has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{42b592d8 V.E..... R.....ID 0,0-502,346} that was originally added here
10-29 08:41:55.510: E/WindowManager(16738):     at android.view.ViewRootImpl.<init>(ViewRootImpl.java:426)
10-29 08:41:55.510: E/WindowManager(16738):     at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:235)
10-29 08:41:55.510: E/WindowManager(16738):     at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:69)
10-29 08:41:55.510: E/WindowManager(16738):     at android.app.Dialog.show(Dialog.java:282)
10-29 08:41:55.510: E/WindowManager(16738):     at com.facebook.android.FbDialog$FbWebViewClient.onPageStarted(FbDialog.java:197)
10-29 08:41:55.510: E/WindowManager(16738):     at android.webkit.CallbackProxy.handleMessage(CallbackProxy.java:399)
10-29 08:41:55.510: E/WindowManager(16738):     at android.os.Handler.dispatchMessage(Handler.java:99)
10-29 08:41:55.510: E/WindowManager(16738):     at android.os.Looper.loop(Looper.java:137)
10-29 08:41:55.510: E/WindowManager(16738):     at android.app.ActivityThread.main(ActivityThread.java:5328)
10-29 08:41:55.510: E/WindowManager(16738):     at java.lang.reflect.Method.invokeNative(Native Method)
10-29 08:41:55.510: E/WindowManager(16738):     at java.lang.reflect.Method.invoke(Method.java:511)
10-29 08:41:55.510: E/WindowManager(16738):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
10-29 08:41:55.510: E/WindowManager(16738):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
10-29 08:41:55.510: E/WindowManager(16738):     at dalvik.system.NativeStart.main(Native Method)
10-29 08:41:56.090: I/GATE(16738): <GATE-M>DEV_ACTION_COMPLETED</GATE-M>
10-29 08:41:56.090: D/AndroidRuntime(16738): Shutting down VM
10-29 08:41:56.095: W/dalvikvm(16738): threadid=1: thread exiting with uncaught exception (group=0x413a1930)
10-29 08:41:56.100: E/AndroidRuntime(16738): FATAL EXCEPTION: main
10-29 08:41:56.100: E/AndroidRuntime(16738): java.lang.IllegalArgumentException: View not attached to window manager
10-29 08:41:56.100: E/AndroidRuntime(16738):    at android.view.WindowManagerGlobal.findViewLocked(WindowManagerGlobal.java:402)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at android.view.WindowManagerGlobal.removeView(WindowManagerGlobal.java:304)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at android.view.WindowManagerImpl.removeView(WindowManagerImpl.java:79)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at android.app.Dialog.dismissDialog(Dialog.java:325)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at android.app.Dialog.dismiss(Dialog.java:307)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at com.facebook.android.FbDialog$FbWebViewClient.onPageFinished(FbDialog.java:203)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at android.webkit.CallbackProxy.handleMessage(CallbackProxy.java:408)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at android.os.Handler.dispatchMessage(Handler.java:99)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at android.os.Looper.loop(Looper.java:137)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at android.app.ActivityThread.main(ActivityThread.java:5328)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at java.lang.reflect.Method.invokeNative(Native Method)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at java.lang.reflect.Method.invoke(Method.java:511)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
10-29 08:41:56.100: E/AndroidRuntime(16738):    at dalvik.system.NativeStart.main(Native Method)

1 ответ

Решение

Удалить эту строку

FbDialog.mSpinner.dismiss();

Если диалог не исчезает, поместите это в try/catch:

try{
     FbDialog.mSpinner.dismiss(); 
 } catch(Exception e ) 
 { e.printStackTrace(); }

И выложи свой стековый след;)

Другие вопросы по тегам