0

:昨日アンドロイドFCM - 私はこのように実装を無効にする/通知を有効

public static void setPushSetting(Context context, boolean flag) { 
    if(flag) { 
     FirebaseInstanceId.getInstance().getToken(); 
    } else { 
     try { 
      FirebaseInstanceId.getInstance().deleteInstanceId(); 
     } catch (IOException e) { 
      RxBus.getInstance().post(new OffPushError()); 
      e.printStackTrace(); 
     } 
    } 
} 

は、それが働いていたが、今日FirebaseInstanceId.getInstance().deleteInstanceId();は常に例外をスローします。

& Firebaseプッシュ通知をディセーブルにする方法はありますか?ご協力いただきありがとうございます!
-------更新例外のログ-------------

java.io.IOException: MAIN_THREAD 
                  at com.google.firebase.iid.zzd.zzb(Unknown Source) 
                  at com.google.firebase.iid.FirebaseInstanceId.deleteInstanceId(Unknown Source) 
                  at jp.seesaa.itmama.push.PushUtil.setPushSetting(PushUtil.java:32) 
                  at jp.seesaa.itmama.ui.main.setting.SettingFragment.onSharedPreferenceChanged(SettingFragment.java:66) 
                  at android.app.SharedPreferencesImpl$EditorImpl.notifyListeners(SharedPreferencesImpl.java:476) 
                  at android.app.SharedPreferencesImpl$EditorImpl.apply(SharedPreferencesImpl.java:384) 
                  at android.support.v4.content.EditorCompatGingerbread.apply(EditorCompatGingerbread.java:25) 
                  at android.support.v4.content.SharedPreferencesCompat$EditorCompat$EditorHelperApi9Impl.apply(SharedPreferencesCompat.java:45) 
                  at android.support.v4.content.SharedPreferencesCompat$EditorCompat.apply(SharedPreferencesCompat.java:67) 
                  at android.support.v7.preference.Preference.tryCommit(Preference.java:1353) 
                  at android.support.v7.preference.Preference.persistBoolean(Preference.java:1558) 
                  at android.support.v7.preference.TwoStatePreference.setChecked(TwoStatePreference.java:79) 
                  at android.support.v7.preference.TwoStatePreference.onClick(TwoStatePreference.java:64) 
                  at android.support.v7.preference.Preference.performClick(Preference.java:971) 
                  at android.support.v7.preference.Preference.performClick(Preference.java:957) 
                  at android.support.v7.preference.SwitchPreferenceCompat.performClick(SwitchPreferenceCompat.java:203) 
                  at android.support.v7.preference.Preference$1.onClick(Preference.java:145) 
                  at android.view.View.performClick(View.java:4780) 
                  at android.view.View$PerformClick.run(View.java:19866) 
                  at android.os.Handler.handleCallback(Handler.java:739) 
                  at android.os.Handler.dispatchMessage(Handler.java:95) 
                  at android.os.Looper.loop(Looper.java:135) 
                  at android.app.ActivityThread.main(ActivityThread.java:5254) 
                  at java.lang.reflect.Method.invoke(Native Method) 
                  at java.lang.reflect.Method.invoke(Method.java:372) 
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 
+0

例外のためにstacktraceをポストしますか?また、ユーザーに対してプロンプトを表示するための通知をオフにするだけですか?それとも完全に登録抹消したいですか? –

+0

私は昨日、instanceIdTokenが削除されたと推測していますが、今日もフラグはfalseとして渡されているため、他の部分はまだ実行されており、削除するトークンIDはないため、NullPointerExceptionです。私の推測は –

+0

@ALです。私はログファイルを更新しました。 2つの方法は私のために大丈夫です –

答えて

5

私はこのような他のスレッドを経て実行することによってそれを修正:

Thread thread = new Thread(() -> { 
       try { 
        FirebaseInstanceId.getInstance().deleteInstanceId(); 
       } catch (Exception e) { 
        Log.e("ERROR", Log.getStackTraceString(e)); 
        RxBus.getInstance().post(new OffPushError()); 
       } 
     }); 
thread.start(); 
2

私も同じ問題があった、deleteInstanceId();のように非同期で実行する必要があります。 AsynTaskクラスを使って解決しました。

private class DeleteTokenTask extends AsyncTask<Void, Void, Void> { @Override protected Void doInBackground(Void... voids) { try { FirebaseInstanceId.getInstance().deleteInstanceId(); } catch (IOException e) { Log.d(TAG, "Exception deleting token", e); } return null; } }

それから私は私が持っているどこからこのようにそれを呼び出す:new DeleteTokenTask().execute();、それがうまく働きました。

+0

あなたのコードは常に私にTIMEOUTを返す:( –

+0

stannge、それは私のために働いた、おそらくより新しいバージョンですか? – Javi

関連する問題