【问题标题】:Firebase notifications FCM not received on iPhone XiPhone X 上未收到 Firebase 通知 FCM
【发布时间】: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),但它没有将其发送到我的应用程序...

另外,为什么会出现这个错误:&lt;Error&gt;: 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


【解决方案1】:

我也有类似的问题。我将优先级设置为高并添加了以下有效负载。

    let message = {
      notification: {
        title: 'title',
        body: `title`
  }
};
   let options = {
     priority: "high",
     timeToLive: 60 * 60 * 24
};

到目前为止一切正常。

【讨论】:

    【解决方案2】:

    FirebaseMessaging (3.0.2) 在 11.4 上出现推送通知问题 尝试使用其他版本,例如 3.0.6

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2021-10-30
      • 2019-08-17
      • 1970-01-01
      • 2021-09-16
      • 1970-01-01
      • 1970-01-01
      • 2018-05-01
      • 1970-01-01
      相关资源
      最近更新 更多