Firebase Cloud Messaging多次发送上游消息,但我发送确认

时间:2016-11-24 16:25:01

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

我正在开发一个通过FCM将数据发送到我的服务器的应用程序。根据{{​​3}},我需要发送一条如下所示的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”是我想要确认的消息的“from”。

我做错了什么?我使用the Firebase Docs作为XMPP库。

1 个答案:

答案 0 :(得分:0)

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

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