Firebase onTokenRefresh() is not called

后端 未结 13 2112
天命终不由人
天命终不由人 2020-11-27 16:59

In my MainActivityin my log, I can see the token using FirebaseInstanceId.getInstance().getToken() and it display the generated token. But it seem

相关标签:
13条回答
  • 2020-11-27 17:15

    Try re-install the app, by uninstall it first from your device or emulator. It will then generate a new token, thus onTokenRefresh() will be called again.

    0 讨论(0)
  • 2020-11-27 17:19

    Reinstalling did the trick for me!

    0 讨论(0)
  • 2020-11-27 17:20

    Make sure you have added

    apply plugin: 'com.google.gms.google-services'

    this to bottom of the app.gradle file

    0 讨论(0)
  • 2020-11-27 17:23

    I had the same problem like you. My mistake was the following: I placed my <service> tags outside the <application> tag in the AndroidManifest.xml file.

    Now mine looks like this:

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
    
        <service
            android:name=".MyFirebaseMessagingService">
            <intent-filter>
                <action android:name="com.google.firebase.MESSAGING_EVENT"/>
            </intent-filter>
        </service>
    
        <service
            android:name=".MyFirebaseInstanceIDService">
            <intent-filter>
                <action android:name="com.google.firebase.INSTANCE_ID_EVENT"/>
            </intent-filter>
        </service>
    </application>
    

    And it works without any problem.

    0 讨论(0)
  • 2020-11-27 17:25

    Yes this might happen some times.

    Please call the following method wherever you want to get your fcm id.

        try {
                String refreshedToken = FirebaseInstanceId.getInstance().getToken();
                Log.d("Firbase id login", "Refreshed token: " + refreshedToken);
            } catch (Exception e) {
                e.printStackTrace();
            }
    
    0 讨论(0)
  • 2020-11-27 17:26

    I've been struggling with that for over an hour, then I changed the following code and it suddenly worked.

    handle your refreshedToken as such:

    String refreshedToken;
        try {
            refreshedToken = FirebaseInstanceId.getInstance().getToken();
            Log.d(TAG, "Refreshed token: " + refreshedToken);
            Localytics.setPushRegistrationId(refreshedToken);
        } catch (Exception e) {
            Log.d(TAG, "Refreshed token, catch: " + e.toString());
            e.printStackTrace();
        }
    

    Try adding android:exported="true"> to both MyFirebaseMessagingService and MyFirebaseInstanceIDService in manifest so it looks like that:

    <service
            android:name="com.localytics.android.sample.fcm.MyFirebaseMessagingService"
            android:exported="true">
            <intent-filter>
                <action android:name="com.google.firebase.MESSAGING_EVENT"/>
            </intent-filter>
        </service>
    
        <service
            android:name="com.localytics.android.sample.fcm.MyFirebaseInstanceIDService"
            android:exported="true">
            <intent-filter>
                <action android:name="com.google.firebase.INSTANCE_ID_EVENT"/>
            </intent-filter>
        </service>
    

    Uninstall your app, Install again, worked. Tested on real device.

    android:exported="true" is a default option so you can also remove that entirely and it will be set to true.

    Also if you want to call onTokenRefresh more explicitly, you can simply call that anywhere in your code:

    String refreshedToken = FirebaseInstanceId.getInstance().getToken();
    Localytics.setPushRegistrationId(refreshedToken);
    

    You don't have to rely on broadcast being received any more

    0 讨论(0)
提交回复
热议问题