4

我正在使用 PushKit 和 CallKit 开发一个 VoIP 应用程序。我知道类似的问题在不同的论坛上经常被问到,但不幸的是从未真正得到回答。此外,这些帖子中的大多数都来自 2015 年左右,所以我认为很有可能已经发生了很多变化,因为有人可能已经想到了如何让它发挥作用。

什么工作:

当应用程序在前台运行或发送到后台时,它使用沙盒服务器以及生产服务器接收推送通知。

我在 iOS 11 和 Xcode 9 上,需要在“功能”中启用常规推送通知,以及手动将 voip 背景模式添加到 info.plist 以调用委托方法。单独连接 CallKit 和 PushKit 不足以接收通知。我还启用了后台音频、后台获取和远程通知。在进行推送注册表注册之前,我还创建了一个后台任务,并在收到推送令牌后结束该任务。

什么不起作用:

重启后唤醒应用程序或强制退出来电。

我在 Instruments 活动监视器中看到来电启动的过程,但看起来有些东西从那里不起作用,因为我没有收到来电 ui。

问题:

  1. 当应用程序未运行时,传入通知的入口点是什么?-pushRegistry:didReceiveIncomingPushWithPayload:forType:或者也许(仅)-application:didFinishLaunchingWithOptions:
  2. 我存储了我的凭据以在钥匙串中向服务器注册。是否有可能在应用程序启动期间查询钥匙串为时过早?

更新:

自己想出了一个解决方案。这更像是客户端和服务器之间的时间问题。所以这对我有用。

  1. 从启动应用程序的服务器发送推送
  2. 收到推送后,给应用程序一些时间在 sip 服务器上启动和重新注册
  3. 使用最新的注册信息向客户端发送邀请

同样重要的是不要过早调用推送通知委托上的完成处理程序,这将使应用程序重新进入睡眠状态并且永远不会收到邀请。

也可能会有所帮助,并且可以使场景更加宽容。如果您的 sip 服务器多次发送邀请,请确保在每个服务器上始终使用最新的注册信息。意思.. 假设第一个 INVITE 发送得太早了一些过时的注册信息,客户端仍然启动尝试更新服务器上的信息......确保下一个使用更新的信息。一些 sip 服务器只使用每次迭代可用的第一个信息。因此,您将永远等待而不会在客户端上收到任何东西。

4

1 回答 1

0
于 2017-11-21T18:31:17.013 回答