向 iOS 设备发送数据消息导致 FirebaseMessagingException:请求包含无效参数

Sending data message to iOS device results in FirebaseMessagingException: Request contains an invalid argument

当我们使用 Firebase Admin SDK 向 iOS 设备发送 FCM 数据消息时,出现以下异常。

com.google.firebase.messaging.FirebaseMessagingException: Request contains an invalid argument.

我们正在使用 com.google.firebase:firebase-admin:6.7.0 消息是这样构建的。

Message.builder()
        .setApnsConfig(ApnsConfig.builder()
            .putHeader("apns-priority", "10")
            .setAps(Aps.builder()
                .setContentAvailable(true)
                .build())
            .build())
        .putAllData(data)
        .setToken(token)
        .build();

我不认为令牌本身有问题,因为向该令牌发送推送通知是有效的。

消息大小也应该不是问题,因为它基本上只是其中的一个 ID。

我不确定它是否发生在所有 iOS 设备上。 我在构建数据消息时遗漏了什么吗?

更新

我检查了异常中包含的详细信息,似乎令牌有问题。

{
  "error": {
    "code": 400,
    "message": "Request contains an invalid argument.",
    "status": "INVALID_ARGUMENT",
    "details": [
      {
        "@type": "type.googleapis.com/google.firebase.fcm.v1.FcmError",
        "errorCode": "INVALID_ARGUMENT"
      },
      {
        "@type": "type.googleapis.com/google.rpc.BadRequest",
        "fieldViolations": [
          {
            "field": "message.token",
            "description": "Invalid registration token"
          }
        ]
      }
    ]
  }
}

但是当我使用邮递员向同一个令牌发送数据消息时,没有错误,响应如下所示。

{
"multicast_id": 7455611938954436367,
"success": 1,
"failure": 0,
"canonical_ids": 0,
"results": [
    {
        "message_id": "0:1614145427166557%c5757de0f9fd7ecd"
    }
]

}

我想我明白了。

我的问题是我将 apns-priority 设置为“10”。根据 documentation,必须立即传送优先级为“10”的通知。

例如,如果我将我的设备置于飞行模式,并发送我的数据推送,它会失败,并出现上述关于无效令牌的 firebase 异常。我认为这是非常误导的。

如果我将 apns-priority 设置为“5”,一切正常。

如果您尝试使用仅包含数据的推送通知(静默推送通知),而无需用户授予在 iOS 上接收的权限,但您设置了一些 [=14],则可能会发生这种情况=]请求中的具体参数。

在这种情况下,如果用户已授予接收推送通知的权限或您未指定任何 iOS 特定参数,则不会发生错误。