当应用程序处于活动状态时通过FCM发送通知 [英] Sending notifications via FCM when app is active

查看:171
本文介绍了当应用程序处于活动状态时通过FCM发送通知的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

即使应用程序是前台,我如何仍保留未读的推送消息?

How can I leave a push message unread, even if the app is foreground?

我正在使用离子技术创建一个应用程序.我使用通过Firebase云消息传递(cordova-plugin-fcm-with-dependecy-updated)的推送通知来订阅消息,并在后端进行发送. 后端请求示例:

I am creating an application using ionic. I use push notifications using firebase cloud messaging (cordova-plugin-fcm-with-dependecy-updated) to subscribe to messages, and backend for sending. Example backend request:

{
   "headers": {
      "Authorization": "key = blahblah",
      "Content-Type": "application / json",
      "project_id": "111111111111"
   },
   "json": {
      "registration_ids": [
         "token"
      ],
      "time_to_live": 1200,
      "data": {
         "title": "title",
         "body": "body",
         "sound": "default",
         "badge": 1,
         "click_action": "FCM_PLUGIN_ACTIVITY"
      }
   }
}

我还尝试发送通知密钥而不是日期密钥.试图添加到根

I also tried to send the notification key instead of the date key. Tried to add to root

{
    ...
    "android": {
        "ttl": "1200s",
        "priority": "high",
        "notification": {
            "click_action": "FCM_PLUGIN_ACTIVITY"
        }
    },
    ...
    "apns":{
        "headers":{
            "apns-priority":10,
            "apns-expiration": date('U') + 1200
        },
        "payload":{
            "aps":{
                "badge":1,
                "category":"FCM_PLUGIN_ACTIVITY"
            }
        }
    }
}

结果是一样的-当应用程序在后台运行时,推送不会显示在托盘中.

The result is the same - when the application is in the background, the push is not displayed in the tray.

如果应用程序处于前台状态,我如何不让推送保持未读状态,而仅在用户点击时才能在this.fcm.onNotification().subscribe(...)调用我的操作?

How can I leave push unread, if app in foreground, and call my actions at this.fcm.onNotification().subscribe(...) only on user's click?

p.s.我尝试使用cordova-plugin-local-notification,但是使用此方法会引起一些冲突-subscribe操作不会在ios中触发

p.s. I tried to use cordova-plugin-local-notification, but using this caused some conflict - subscribe action doesn't fire in ios

推荐答案

我在应用程序中使用了ionic和cordova.

I use ionic and cordova in my app.

我正在使用插件[cordova-plugin-firebasex]( https://github. com/dpa99c/cordova-plugin-firebasex )以接收推送.

I am using the plugin [cordova-plugin-firebasex] (https://github.com/dpa99c/cordova-plugin-firebasex) to receive push.

要发送推送,请使用以下json:

To send the push, use the following json:

{
  "registration_ids": [
      "token"
  ],
  "notification":{
    "title":"Ionic 4 Notification",
    "body":"Notification sent from POSTMAN",
    "sound":"default",
    "click_action":"FCM_PLUGIN_ACTIVITY",
    "icon":"notification_icon"
  },
  "data":{
    "email":"teste@gmail.com"
  },
  "priority":"high"
}

对于android,通知"该字段在应用程序处于后台时显示通知.

For android, the "notification" field that displays a notification when the application is in the background.

如果您处于前台,则必须使用插件[cordova-plugin-local-notifications]( https://github.com/katzer/cordova-plugin-local-notifications )

If you are in foreground, you have to display a notification yourself using the plugin [cordova-plugin-local-notifications] (https://github.com/katzer/cordova-plugin-local-notifications)

我的代码:

constructor(private firebaseCordova: FirebaseX) {}

private initializePushApp() {
    this.checkNotificationPermission(false);
    this.onMessageApp();
}

checkNotificationPermission(requested) {
    try {
        this.firebaseCordova.hasPermission().then(hasPermission => {
            if (hasPermission) {
                this.getTokenApp();
            } else if (!requested) {
                this.firebaseCordova.grantPermission().then(value => {
                    this.checkNotificationPermission(true);
                });
            } else {
                // Denied
                console.log("Notifications won't be shown as permission is denied");
            }
        });
    } catch (e) {
        console.error(e);
    }
}

onMessageApp() {
    try {
        this.firebaseCordova.onMessageReceived().subscribe(data => {
            this.showNotificationCordova(data);
        });
    } catch (e) {
        console.error(e);
    }
}

showNotificationCordova(notification) {
    if ('background' === notification.tap) {
        // click on notification in background
        alert(notification.title);
    } else {
        this.clickNotificationSub = this.localNotifications.on('click').subscribe(data => {
            // click on notification in foreground
            alert(notification.title);
        });

        this.localNotifications.hasPermission().then(permission => {
            if (permission) {
                this.localNotifications.schedule({
                    id: 1,
                    title: notification.title,
                    text: notification.body,
                    icon: notification.image ? notification.image : 'notification_icon',
                });
            } else {
                this.localNotifications.requestPermission().then(value => {
                    if (value) {
                        this.localNotifications.schedule({
                            id: 1,
                            title: notification.title,
                            text: notification.body,
                           icon: notification.image ? notification.image : 'notification_icon',
                        });
                    } else {
                        console.log("Notifications won't be shown as permission is denied");
                    }
                });
            }
        });
    }
}

当您输入此条件'background'=== notification.tap`时,将在后台单击该通知

When you enter this condition 'background' === notification.tap` the notification was clicked in the background

这篇关于当应用程序处于活动状态时通过FCM发送通知的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆