我正在使用 PushKit 和 CallKit 开发一个 VoIP 应用程序。我知道类似的问题在不同的论坛上经常被问到,但不幸的是从未真正得到回答。此外,这些帖子中的大多数都来自 2015 年左右,所以我认为很有可能已经发生了很多变化,因为有人可能已经想到了如何让它发挥作用。
什么工作:
当应用程序在前台运行或发送到后台时,它使用沙盒服务器以及生产服务器接收推送通知。
我在 iOS 11 和 Xcode 9 上,需要在“功能”中启用常规推送通知,以及手动将 voip 背景模式添加到 info.plist 以调用委托方法。单独连接 CallKit 和 PushKit 不足以接收通知。我还启用了后台音频、后台获取和远程通知。在进行推送注册表注册之前,我还创建了一个后台任务,并在收到推送令牌后结束该任务。
什么不起作用:
重启后唤醒应用程序或强制退出来电。
我在 Instruments 活动监视器中看到来电启动的过程,但看起来有些东西从那里不起作用,因为我没有收到来电 ui。
问题:
- 当应用程序未运行时,传入通知的入口点是什么?
-pushRegistry:didReceiveIncomingPushWithPayload:forType:
或者也许(仅)-application:didFinishLaunchingWithOptions:
? - 我存储了我的凭据以在钥匙串中向服务器注册。是否有可能在应用程序启动期间查询钥匙串为时过早?
更新:
自己想出了一个解决方案。这更像是客户端和服务器之间的时间问题。所以这对我有用。
- 从启动应用程序的服务器发送推送
- 收到推送后,给应用程序一些时间在 sip 服务器上启动和重新注册
- 使用最新的注册信息向客户端发送邀请
同样重要的是不要过早调用推送通知委托上的完成处理程序,这将使应用程序重新进入睡眠状态并且永远不会收到邀请。
也可能会有所帮助,并且可以使场景更加宽容。如果您的 sip 服务器多次发送邀请,请确保在每个服务器上始终使用最新的注册信息。意思.. 假设第一个 INVITE 发送得太早了一些过时的注册信息,客户端仍然启动尝试更新服务器上的信息......确保下一个使用更新的信息。一些 sip 服务器只使用每次迭代可用的第一个信息。因此,您将永远等待而不会在客户端上收到任何东西。