java - Firebase Cloud Messaging 多次发送上游消息,尽管我发送了确认

标签 java google-cloud-messaging xmpp firebase-cloud-messaging smack

我正在开发一个通过 FCM 将数据发送到我的服务器的应用程序。根据the Firebase Docs ,我需要发送一条 ACK 消息,如下所示:

<message id="">
  <gcm xmlns="google:mobile:data">
  {
      "to":"REGID",
      "message_id":"m-123"
      "message_type":"ack"
  }
  </gcm>
</message>

我的服务器收到我从 Android 应用程序发送的消息,并发送此 Ack 消息:

<message to="devices@gcm.googleapis.com" id="R88Ub-10">
    <gcm xmlns="google:mobile:data">
    {
        "to":"dpDymtuUdEO-...-MRDQvLXMhfnEEUqEYZfs",
        "message_id":"64cc690-...-227a0b7eb61",
        "message_type":"ack"
    }
    </gcm>
</message>

(“-...-”部分只是为了缩短/匿名化代码)

但是如果我重新启动我的服务器,我会收到一些我已经收到的消息,并且已经准备好发送 ACK...我在标签中没有“to”和“id”的情况下进行了测试,但似乎没有任何效果。

我在 ACK 消息中使用的“to”是我想要 ACK 的消息的“from”。

我做错了什么?我用Smack作为 XMPP 库。

最佳答案

与 Firebase 团队联系后,我们发现将消息的 TTL(生存时间)设置为“0”会有所帮助。发送 FCM 消息的代码现在如下所示:

                 fcm.send(new RemoteMessage.Builder(FCMConstants.SENDER_ID + "@gcm.googleapis.com")
                  .setMessageId(msgid)
                  .setData(data)
                  .setTtl(0)
                  .build());

关于java - Firebase Cloud Messaging 多次发送上游消息,尽管我发送了确认,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40791072/

相关文章:

java - 实例化 Groovy 类的正确方法

java - UTF-8写入xml成功

Android gcm 项目服务器 key 需要一次又一次重新生成

android - 如何在 Node 服务器中处理 FCM 上游消息?

python - 为什么所有 twisted/wokkel xmpp 示例都忽略了 xmpp 协议(protocol)中 JID 的正确用法?

Java/替换所有引号

java - 使用克隆进行深度复制

java - 我发送 7 条消息抛出 GCM 并收到 35 条消息的响应

java - 如何编写 Google Cloud Messaging 的 POST 请求?

c# - 是否有任何支持 WinRT 的免费 XMPP 库?