Android FCM - 禁用/启用通知

Cuo*_*yen 0 android firebase firebase-cloud-messaging firebase-notifications

我这样实现:

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();
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

昨天,它有效,但今天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)
Run Code Online (Sandbox Code Playgroud)

Cuo*_*yen 6

我通过运行其他线程修复它,如下所示:

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


Sho*_*omu 5

删除 Firebase 实例 ID 和令牌

删除 firebase 实例 ID 必须在后台线程中调用

AsyncTask.execute(() -> {
            try {
                FirebaseInstanceId.getInstance().deleteInstanceId();
                Log.d("TAG","Fb deleteInstanceId!");
            } catch (IOException e) {
                Log.e("TAG","Error: Fb deleteInstanceId:" + e.toString());
            }
        });
Run Code Online (Sandbox Code Playgroud)