【发布时间】:2018-12-04 11:44:50
【问题描述】:
我有一个 iOS 应用 (Xcode 9 / Swift 4),它使用 Firebase Cloud Messaging 接收 silent push notifications
应用已经发布,但 iPhone X 用户没有收到通知
我已经对所有内容进行了三次检查,所有内容都是最新的,包括 Google Pods FirebaseMessaging (3.0.2)
生成静默推送通知的我的服务器应用程序 (c#) 也在使用最新版本的 Google APIs (1.34)
所以使用生成通知的应用程序来测试 iPhone 是否收到通知,我得到了以下结果:
- 连接到 Xcode 的 iPhone 6S 收到通知
- iPhone 6S 运行 testflight 版本收到通知
- 运行应用商店版本的iPhone 6S收到通知
- 连接到 Xcode 的 iPhone X 收到通知
- 运行 testflight 版本的 iPhone X 收不到
- iPhone X 运行应用商店版本不接收
这是最糟糕的部分......如果我从 c# 应用程序中获取 iPhone X 令牌并通过 Firebase 控制台发送一条消息,它将被 testflight 版本接收(我想这证明了我正在发送的令牌to 是正确的)
我知道我没有提供代码,但实际上没有什么可检查的......一切都在 iPhone 6S 上运行良好,甚至在 iPhone X 上与 Xcode 绑定时。
我在想不知何故我的服务器 IP 地址无法从 iPhone X 访问,但事实并非如此,因为在应用程序启动期间我连接到服务器并下载数据没有问题......就像 iPhone X 有某种防火墙以防止来自我的 IP 的传入消息? 即使我知道我在 iPhone X 上拥有应用通知权限(我可以从 Firebase 控制台发送消息),我还是在应用内创建了一个日志屏幕,并且知道该权限已启用。
我错过了什么吗???是否需要为 iPhone X 启用其他我不知道的权限?
编辑: iPhoneX iOS 版本 = 11.4
EDIT2: 似乎,由于某种原因,iPhone X 需要有效载荷包含 "notification: {"title":"xxx", "body":"xxx"}",这是没有意义的,因为 iPhone 6S 可以在没有添加有效载荷的情况下接收静默推送通知。 . 现在的问题是,在有效负载中添加“通知”将使 iOS 在收到通知后立即在托盘上显示通知,这超出了我想要传递的“静默”通知的目的。
这是之前在 iPhone X 上不工作但在 iPhone 6S 上工作的有效负载(FCM 负责添加 content-available 标签):
{"message": {"token" : "eANw_OLOKXc:APA.....XsMg", "data" : {"content" : "2546|N|495....arg|BATTERY|||||"}}}
这是一个适用于 iPhone X 但会弹出系统通知的那个,我不想要:
{"message": {"token" : "eANw_OLOKXc:APA.....XsMg", "notification":{"title":"xxx","body":"xxx"},"data" : {"content" : "2546|N|495....arg|BATTERY|||||"}}}
为什么没有notification 有效载荷,iPhone 6S 也能工作?以及如何向 iPhone X 发送静音通知
编辑 3: 我想唯一的选择是启动一个新项目并复制问题,因为我被卡住了......我不明白为什么通过运行与 Xcode 绑定的项目让它在 iPhone X 上工作,但在没有插入 USB 电缆的情况下运行时,它不会收到通知。 我忘了说 iPhone 6S 也在 iOS 11.4 上
编辑 4:我设法在无提示通知到达的那一刻直接从 iPhone X 获取一些日志:
Jun 26 01:08:46 MP apsd[9726] <Notice>: APSMessageStore - APSIncomingMessageRecordDeleteMessageForGUID <private>
Jun 26 01:08:46 MP SpringBoard(UserNotificationsServer)[9680] <Notice>: Received incoming message on topic com.mydomain.myapp2 at priority 1
Jun 26 01:08:46 MP SpringBoard(UserNotificationsServer)[9680] <Notice>: [com.mydomain.myapp2] Received remote notification request C752-66DA [ hasAlertContent: 0, hasSound: 0 hasBadge: 0 hasContentAvailable: 1 hasMutableContent: 0 ]
Jun 26 01:08:46 MP SpringBoard(UserNotificationsServer)[9680] <Notice>: [com.mydomain.myapp2] Deliver push notification request C752-66DA
Jun 26 01:08:46 MP SpringBoard(UserNotificationsServer)[9680] <Notice>: [com.mydomain.myapp2] Passing content-available push to Duet
Jun 26 01:08:46 MP SpringBoard(DuetActivityScheduler)[9680] <Notice>: SUBMITTING: <private>
Jun 26 01:08:46 MP SpringBoard(UserNotificationsServer)[9680] <Error>: Ignoring notification with no alert, sound or badge (com.mydomain.myapp2): C752-66DA
Jun 26 01:08:46 MP SpringBoard(UserNotificationsServer)[9680] <Notice>: [com.mydomain.myapp2] Not saving push notification C752-66DA to store [ error=Error Domain=UNErrorDomain Code=1401 "Notification has no user-facing content" UserInfo={NSLocalizedDescription=Notification has no user-facing content} ]
Jun 26 01:08:46 MP dasd(DuetActivitySchedulerDaemon)[9752] <Notice>: Submitted Activity: com.apple.pushLaunch.com.mydomain.myapp2:2AD94B <private>
Jun 26 01:08:46 MP dasd(DuetActivitySchedulerDaemon)[9752] <Notice>: Daemon Canceling Activities: {(
com.apple.pushLaunch.com.mydomain.myapp2:2AD94B
)}
Jun 26 01:08:46 MP dasd(DuetActivitySchedulerDaemon)[9752] <Notice>: CANCELED: com.apple.pushLaunch.com.mydomain.myapp2:2AD94B <private>!
因此,iOS 似乎收到了通知以及数据 (hasContentAvailable: 1),但它没有将其发送到我的应用程序...
另外,为什么会出现这个错误:<Error>: Ignoring notification with no alert, sound or badge... 无提示通知没有警报/声音/徽章!
【问题讨论】:
-
这似乎是 APN 的问题。 Firebase 将信息发送到实际处理通知的 APNs。见this other SO question
-
如果您直接通过 APN 向您的 iPhone X 发送通知会发生什么?
-
我从不直接使用 APN,总是通过 google FCM
标签: ios firebase push-notification apple-push-notifications firebase-cloud-messaging