未接收 Firebase 云消息/通知。JS

Nom*_*Ali 6 javascript firebase reactjs google-cloud-functions firebase-cloud-messaging

我正在尝试使用云功能将 FCM 发送到我的 React 应用程序。云函数正在执行,但客户端未收到通知。

这里是云函数代码。

exports.sendPush = functions.database.ref('/settings2').onWrite(event => {
    let projectStateChanged = false;
    let projectCreated = false;
    let projectData = event.data.val();
    if (!event.data.previous.exists()) {
        projectCreated = true;
    }
    if (!projectCreated && event.data.changed()) {
        projectStateChanged = true;
    }
    let msg = 'A project state was changed';
        if (projectCreated) {
            msg = `The following new project was added to the project: ${projectData.title}`;
        }
    tokens.push("fIGxxxxGtDGxxxx DEVICE Token");
    let payload = {
        notification: {
            title: 'Firebase Notification',
            body: 'This Is Message',
            sound: 'default',
            badge: '1'
        }
    };
    return admin.messaging().sendToDevice(tokens, payload);
});
Run Code Online (Sandbox Code Playgroud)

这是云函数的日志

在此输入图像描述

这是我客户端的代码:

messaging.onMessage(function(payload) {
   console.log("Message received. ", payload);
      // ...
});
Run Code Online (Sandbox Code Playgroud)

没有任何错误,但控制台中没有任何内容。我需要对 Service Worker 文件执行某些操作吗?

任何帮助,将不胜感激。

Nom*_*Ali 3

我的firebase-messaging-sw.js文件存在问题。我已经通过以下代码解决了这个问题。

importScripts('https://www.gstatic.com/firebasejs/3.9.0/firebase-app.js');
importScripts('https://www.gstatic.com/firebasejs/3.9.0/firebase-messaging.js');

var config = {
    apiKey: "AIzaSyDtg4aQMQW67Jla1nUzrTTSEhVqpUeqKXI",
    authDomain: "payxxxxxxx.firebaseapp.com",
    databaseURL: "https://pxyxxxxx.firebaseio.com",
    projectId: "pxxoll-pxxxs-fxxx",
    storageBucket: "pxxx-pxxx-fxxxx1.apxxxot.com",
    messagingSenderId: "2xxxx5xxx"
  };
  firebase.initializeApp(config);


const messaging = firebase.messaging();
Run Code Online (Sandbox Code Playgroud)