我正在尝试使用云功能将 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);
});

这是云功能的日志

javascript - 未收到 Firebase 云消息/通知。 JS-LMLPHP

这是我客户端的代码:
messaging.onMessage(function(payload) {
   console.log("Message received. ", payload);
      // ...
});

没有任何错误,但控制台中没有任何内容。我必须对 Service Worker 文件做些什么吗?

任何帮助,将不胜感激。

最佳答案

我的 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();

关于javascript - 未收到 Firebase 云消息/通知。 JS,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/46525074/

10-11 19:59