Java Android FirebaseMessagingService: onMessageReceived вообще не вызывается

У меня проблема с моим java-классом FirebaseMessagingService. Когда я отправляю уведомление с консоли Firebase, функция onMessageReceived вообще не вызывается. Но я знаю, что успешно отправил уведомление, вот мой код:

package com.nufdev.firelink.other;

import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.media.RingtoneManager;
import android.net.Uri;
import android.support.v4.app.NotificationCompat;
import android.util.Log;

import com.google.firebase.messaging.FirebaseMessagingService;
import com.google.firebase.messaging.RemoteMessage;
import com.nufdev.firelink.MainActivity;
import com.nufdev.firelink.R;

public class MyFirebaseMessagingService extends FirebaseMessagingService {
    private static final String TAG = "MyFirebaseMsgService";

    /**
     * Called when message is received.
     *
     * @param remoteMessage Object representing the message received from Firebase Cloud Messaging.
     */
    // [START receive_message]
    @Override
    public void onMessageReceived(RemoteMessage remoteMessage) {

        Log.d(TAG, "From: " + remoteMessage.getFrom());

        // Check if message contains a data payload.
        if (remoteMessage.getData().size() > 0) {
            Log.d(TAG, "Message data payload: " + remoteMessage.getData());
        }

        // Check if message contains a notification payload.
        if (remoteMessage.getNotification() != null) {
            Log.d(TAG, "Message Notification Body: " + remoteMessage.getNotification().getBody());
            sendNotification(remoteMessage.getNotification().getBody());

        }

        // Also if you intend on generating your own notifications as a result of a received FCM
        // message, here is where that should be initiated. See sendNotification method below.
    }
    // [END receive_message]

    /**
     * Create and show a simple notification containing the received FCM message.
     *
     * @param messageBody FCM message body received.
     */
    private void sendNotification(String messageBody) {
        Intent intent = new Intent(this, MainActivity.class);
        intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
        PendingIntent pendingIntent = PendingIntent.getActivity(this, 0 /* Request code */, intent,
                PendingIntent.FLAG_ONE_SHOT);

        Uri defaultSoundUri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
        NotificationCompat.Builder notificationBuilder = new NotificationCompat.Builder(this)
                .setSmallIcon(R.drawable.icon_send)
                .setContentTitle("FCM Message")
                .setContentText(messageBody)
                .setAutoCancel(true)
                .setSound(defaultSoundUri)
                .setContentIntent(pendingIntent);

        NotificationManager notificationManager =
                (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

        notificationManager.notify(0 /* ID of notification */, notificationBuilder.build());
    }

    @Override
    protected Intent zzaa(Intent intent) {
        Log.v(TAG, "ZZZA?");
        return null;
    }
}  

Всякий раз, когда я отправляю уведомление из консоли Firebase, я получаю в консоли только: ZZAA? из-за этого :

@Override
        protected Intent zzaa(Intent intent) {
            Log.v(TAG, "ZZZA?");
            return null;
        }

Я понятия не имею, что означает zzaa, и не могу найти его в Google.
Если бы вы могли мне помочь, это было бы здорово. :D


person NufMeister    schedule 04.10.2016    source источник
comment
Вы добавили правильное разрешение в androidmanifest.xml?   -  person Kirtikumar A.    schedule 05.10.2016
comment
Да, я добавил разрешение на доступ в Интернет и добавил свой класс в качестве службы... Так что я действительно не знаю, почему функция не вызывается...   -  person NufMeister    schedule 05.10.2016
comment
Какой смысл переопределять метод zzaa. Я не уверен, но возвращаю null, который должен сломать код, который отображает сообщение, если есть проверка null   -  person Emre Aktürk    schedule 24.01.2017
comment
Я только что проверил исходный код, и есть нулевая проверка. Не переопределяйте его. Поскольку код скрыт, возвращаемое значение используется для открытия намерения при нажатии уведомления, если я правильно понял   -  person Emre Aktürk    schedule 24.01.2017


Ответы (2)


Возможно, вы забыли добавить это в манифест (взято из руководства)

<service
    android:name=".MyFirebaseMessagingService">
    <intent-filter>
        <action android:name="com.google.firebase.MESSAGING_EVENT"/>
    </intent-filter>
</service>
person Rune Schjellerup Philosof    schedule 06.10.2016

Кажется, у FCM есть два типа уведомлений. Консоль FCM всегда отправляет «уведомление», которое срабатывает onMessageReceived, только если приложение находится на переднем плане. Подробнее о концепции: https://firebase.google.com/docs/cloud-messaging/concept-options

Объяснение в примере кода быстрого запуска FCM:

// [START receive_message]
@Override
public void onMessageReceived(RemoteMessage remoteMessage) {
    // [START_EXCLUDE]
    // There are two types of messages data messages and notification messages. Data messages are handled
    // here in onMessageReceived whether the app is in the foreground or background. Data messages are the type
    // traditionally used with GCM. Notification messages are only received here in onMessageReceived when the app
    // is in the foreground. When the app is in the background an automatically generated notification is displayed.
    // When the user taps on the notification they are returned to the app. Messages containing both notification
    // and data payloads are treated as notification messages. The Firebase console always sends notification
    // messages. For more see: https://firebase.google.com/docs/cloud-messaging/concept-options
    // [END_EXCLUDE]

    // TODO(developer): Handle FCM messages here.
    // Not getting messages here? See why this may be: https://firebase.google.com/support/faq/#fcm-android-background
    Log.d(TAG, "From: " + remoteMessage.getFrom());
person Weishi Z    schedule 23.01.2017