向 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 特定参数,则不会发生错误。
当我们使用 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 特定参数,则不会发生错误。