SDK 概述
JPush iOS
从上图可以看出,JPush iOS Push 包括 2 个部分,APNs 推送(代理),与 JPush 应用内消息。
红色部分是 APNs 推送,JPush 代理开发者的应用(需要基于开发者提供的应用证书),向苹果 APNs 服务器推送。由 APNs Server 推送到 iOS 设备上。
蓝色部分是 JPush 应用内推送部分,即 App 启动时,内嵌的 JPush SDK 会开启长连接到 JPush Server,从而 JPush Server 可以推送消息到 App 里。
APNs 通知
APNs 通知:是指通过向 Apple APNs 服务器发送通知,到达 iOS 设备,由 iOS 系统提供展现的推送。用户可以通过 IOS 系统的 “设置” >> “通知” 进行设置,开启或者关闭某一个 App 的推送能力。
JPush iOS SDK 不负责 APNs 通知的展现,只是向 JPush 服务器端上传 Device Token 信息,JPush 服务器端代理开发者向 Apple APNs 推送通知。
应用内消息
应用内消息:JPush iOS SDK 提供的应用内消息功能,在 App 在前台时能够收到推送下来的消息。App 可使用此功能来做消息下发动作。
此消息不经过 APNs 服务器,完全由 JPush 提供功能支持。
APNs 通知与应用内消息对比
如果只需要发送通知,则可以忽略应用内消息的处理。对于两种消息的代码处理可以参考 API 部分的描述。
JPush API v3 支持同时一次调用同时推送 APNs 通知与 JPush 应用内消息。这在某些应用场景里是有意义的。
如果应用后台或退出,会有系统的 APNS 提醒。如果应用处于打开状态,则不展示,iOS 10 开始可实现前台展示。
非 APNS,默认不展示。可通过获取接口自行编码处理。 Apple 提供的接口: didReceiveRemoteNotification JPush 提供的接口: networkDidReceiveMessage- Notification Service Extension 证书配置时需要注意 BundleID 不能与 Main Target 一致,证书需要单独额外配置。
- 请将 Notification Service Extension 中的 Deployment Target 设置为 10.0。
- 在 XCode 7 或者更低的版本中删除 Notification Service Extension 所对应的 Target。
- 在 XCode 7 或者更低的版本中请将引入的 'UserNotifications.framework' 删除。
- 极光从 JPush iOS SDK v4.9.0、JCore iOS SDK v4.1.0 版本起不再支持 armv7 和 armv7s 架构。
- JPush SDK v4.9.0 、JCore SDK v4.1.0 支持的iOS系统版本为 iOS 11.0 及以上版本。
- 头文件 JPUSHService.h
- 静态库文件 jpush-ios-x.x.x.a,jcore-ios-x.x.x.a
- 请参考 iOS 常见问题
-
减少开发及维护成本:
- 应用开发者不需要去开发维护自己的推送服务器与 APNs 对接。
- 集成了 JPush iOS SDK 后不必自己维护更新 device token。
- 通过 JPush 的 Web Portal 直接推送,也可以调用 JPush 的 HTTP 协议 API 来完成,开发工作量大大减少。
-
减少运营成本:
- 极光推送支持一次推送,同时向 Android, iOS两个平台推送。支持统一的 API 与推送界面。
- 极光推送提供标签、别名绑定机制,以及提供了非常细分的用户分群方式,运营起来非常简单、直观。
-
提供应用内推送:
- 除了使得 APNs 推送更简单,也另外提供应用内消息推送。这在类似于聊天的场景里很有必要。
JPush APNs 实现
JPush APNs 的实现可以参考极光社区的一篇文章: APNs 推送原理及问题
JPush APNs 通知的意义
iOS 平台上推送通知,只有 APNs 这个官方的通道,是可以随时送达的。一般开发者都是自己部署应用服务器向 APNs Server 推送。
JPush iOS 推送相比直接向 APNs 推送有什么好处呢?