我没有收到有关申请的FCM推送通知.离子3和角



好日子,这是我在网站上的第一个出版物,如果我不遵守所有出版物规则,我深表歉意,因为我不详细了解它们。

评论我的问题的一步。我有一个用离子3和Angular制成的应用程序,该应用程序可以与用户之间的通知一起出现操作,调查Firebase论坛和其他几个地方,并尝试了几个代码,但我无法修复它。该应用程序将数据和通知发送给特定令牌,由令牌注册的设备接收数据,而不是通知。当应用程序打开时,或者在后台或关闭时,不是当时。这是您使用的代码:

1(接收令牌

 this.fcm.getToken (). then (token => {
         alert ('token' + JSON.stringify (token))
         // Here I save the token I receive from the device
      })

这有效..我可以获取设备令牌。

2(接收通知:

this.fcm.onNotification (). subscribe (data => {
        if (data.wasTapped) {
          alert ("Received in background")
        } else {
          alert ("Received in foreground")
        };
      })

这也有效,当我从firebase控制台发送通知时,我会完美地。问题是当我从服务器发送

时,

3(通知代码:

SendNotific ()
{
let keytoken = 'fqN5yelN7gk: APA91bGT0 ......'
let keyserver = 'AAAA4oCrTNk: APA91bHLBWcyQimF ....'
let headers = {'Authorization': 'key =' + keyserver,
'Content-Type': 'application / json'};
let url = 'https://fcm.googleapis.com/fcm/send';
let body = {
"notification":{
"title": "notification title",
"body": "notification body"
},
"data":{
"key1": "value1",
"key2": "value2"
},
"to": keytoken,
"priority": "high",
"content_available": true
}
this.http.post (url, body, headers) .then (data =>
{
alert (JSON.stringify (data))
}). then (error => {
alert ('error' + JSON.stringify (error))
})
}

如果应用程序在设备的前景的前景中,则警报变得可见,也就是说,我在"数据"中收到了发送的数据。(对于这种情况,它将是" key1"one_answers" key2"(,但我没有收到任何通知。如果应用程序在后台或封闭式中,则未显示通知,当我再次打开应用程序时,警报消息将显示出到达的"数据"。

正如我之前所说的

显然我缺少一些我找不到的数据。.我看到了几个谈论同一件事的出版物,但我无法提供解决方案。

我会在通知中缺少特定数据,以便可见吗?

用户是否需要接受任何许可才能接收通知?

非常感谢您,很抱歉,如果我无法清楚地解释

问:

朱利安。

因此,我在代码中注意到的第一件事是Sender中缺少headers。标头应该是:

let headers = {
               'Authorization': 'key=' + keyserver,
               'Content-Type': 'application / json',
               'Sender': 'id=' + senderId
              };

身体将具有totokendevice token,即收件人。因此,身体将是:

let body = {
  "token": keytoken,
  "notification":{
    "title": "notification title",
    "body": "notification body"
  },
  "data":{
    "key1": "value1",
    "key2": "value2"
  },
  "priority": "high",
  "content_available": true
}

,而且,我认为您想承诺http并在http.post中捕获错误。在这种情况下,代码应该看起来像:

this.http.post(url, body, headers).toPromise().then(data =>
{
  alert (JSON.stringify(data));
}).catch( error => {
  alert ('error' + JSON.stringify (error));
})

相关内容

  • 没有找到相关文章

最新更新