3

我正在实现一个使用 SIP 协议的 VOIP 应用程序。根据 SIP,我需要以一定的时间间隔刷新我在 SIP 服务器上的注册。但是,当我的应用程序进入后台时,我的 keepalive 处理程序仅在 600 秒后根据文档操作系统 Apple 被调用。但这不是 SIP 协议所希望的。为了能够保持与服务器的连接并接收来电,即使应用程序处于后台,我也需要在 600 秒之前发送注册消息。根据 Apple 文档,这是不可能的,但我仍然在 AppStore 上看到了在后台运行的应用程序,即使注册间隔为 60 秒,它们也会在 SIP 服务器上保持注册。他们使应用程序始终在后台运行。那么这怎么可能呢?我知道在后台播放无声音频会继续存在,但 AppReview 进程会拒绝它。但如果是这样,Apple 是如何允许 AppStore 上其他此类应用的呢?有没有一些标准的方法来实现我上面描述的?任何帮助表示赞赏。

4

1 回答 1

4

您不必更频繁地发送注册信息。您可以执行以下操作:配置您的服务器以将保持活动包发送到您的 sip 客户端,以保持 TCP 连接打开。您的服务器应该支持 TCP 连接,并且您的客户端应该通过 TCP 进行通信,因为苹果在后台模式下非常严格,并且只允许 TCP 连接在后台保持打开状态(如果您的 TCP 套接字使用 CFReadStreamRef 包装)。

问题是没有注册消息,这可以由客户端通过指定连接尝试之间的时间来配置,并且 sip 服务器在 2 个注册消息之间间隔一小时就可以了。真正的问题是,如果有来电或 IM,服务器将如何联系 sip 客户端。大多数 sip 客户端没有公共 IP 地址,但很可能它们位于 NAT 后面。因此 sip 服务器无法打开与 sip 客户端的直接连接,因此您必须在客户端和服务器之间保持一个套接字打开。

应用商店中没有一个应用发送注册消息的频率超过 600 秒。

您使用自己的库进行 sip 还是使用 pjsip?如果您使用 pjsip,我可以给您更多提示。您打算使用什么 SIP 服务器?

一些提示:

  • 确保在 app-info.plist 中将所需的背景模式设置为“应用程序提供 IP 语音服务”和“应用程序播放音频”

  • 如果您的应用程序不会绑定到您自己的 sip 服务器,则为用户提供一种禁用 allow_contact_rewrite pjsip 参数的方法(通常您希望启用它以绕过 nat 问题),因为某些会话边界控制器对此不满意特征

  • 确保,如果您在主线程中捕获从 sip 线程发送的消息,您正在使用一种方法将它们发布到主线程中

  • 这里描述了一些其他有趣的问题

  • 准备了很多咖啡:))

于 2012-05-24T07:30:20.133 回答