Firebase 云消息传递为已取消订阅的令牌返回 200 OK

Posted

技术标签:

【中文标题】Firebase 云消息传递为已取消订阅的令牌返回 200 OK【英文标题】:Firebase Cloud Messaging returns 200 OK for token that has unsubscribed 【发布时间】:2020-05-28 03:45:03 【问题描述】:

我们使用 Firebase Java SDK (com.google.firebase:firebase-admin) 向 iosandroid 设备发送推送通知。

我们可以成功构建通知,并使用注册的 FCM 令牌将其发送到设备。

在这样的设备上,我们打开了系统设置,并禁用了应用程序的推送通知。 我们使用 FCM 发送了一个新通知,但它没有出现在设备上 - 正如预期的那样。 但是,我们现在预计 Firebase API 应该抛出异常,因为 FCM 令牌不再有效/已被撤销。

我们认为它可能会被缓存一段时间,但现在已经超过 24 小时。如果在设备上禁用了推送,我们需要能够回退到其他交付方式。 为什么 FCM 还是返回 200 OK?

【问题讨论】:

【参考方案1】:

为应用禁用通知不会自动取消该应用在 Firebase 云消息传递中的注册。如果您重新启用该应用程序的通知,操作系统将愉快地再次发送通知,并且它将(据我所知)继续使用相同的令牌。

【讨论】:

我现在已经完全删除了应用程序,这应该会使令牌失效,但 FCM 仍然接受消息并尝试传递它。也已经超过 24 小时了 我还没有找到这个问题的答案。如果用户禁用推送通知或删除应用程序,我们需要能够回退到其他方法来通知他们。我们应该怎么做? 如果用户表示他们不想从您的应用接收通知,Android 将接受该请求。如果用户卸载应用程序,它肯定没有办法显示通知。这两者都是设计和故意的。除了使用完全独立的系统(例如电子邮件或短信)通知他们之外,没有其他解决方法。但在您这样做之前请仔细考虑,因为用户选择禁用来自您的应用的通知和/或卸载它是有原因的。

以上是关于Firebase 云消息传递为已取消订阅的令牌返回 200 OK的主要内容,如果未能解决你的问题,请参考以下文章

订阅和取消订阅主题 - firebase

Firebase 云消息传递 - 如何验证令牌?

如何向 FCM(Firebase 云消息传递)令牌的特定用户发送消息?

Firebase 云消息传递 - iOS - 未注册或无法订阅主题

Firebase 云消息传递令牌和服务器密钥有啥区别?

如何在 Flutter 中删除 Firebase 云消息传递令牌