logo
当前页

实现静默推送

功能简介

静默推送属于特殊的远程通知,主要用于后台运行的 App 和服务器进行数据同步,例如:App 不在活跃时,App 内数据已经过时,服务器会发送静默推送,此时 App 则进行数据更新,用户全程无感知。

注意
  • 静默推送主要用于更新和同步数据,用户对其无感知,因此静默推送一般不设置内容、声音和角标通知。
  • 静默推送唤醒后台 App 并执行下载任务时,最多有 30 秒时间执行。
  • App 处于前/后台运行时、后台进程被挂起(保留 App 内存资源)时均可触发对应通知回调,App 关闭后不能触发回调。
  • 静默推送请求在 APNs 属于低优先级任务,苹果不保证静默推送的到达率。
  • 不要利用静默推送对 App 进行保活,APNs 若检测到较高频率的静默推送的发送请求,可能会终止其发送。
说明

本文档适用于以下平台:iOS 和 Android(仅限支持 Google 服务的智能设备)。

前提条件

在实现静默推送之前,请确保:

  • 已集成 ZPNs SDK 2.3.1 或以上版本 并实现离线推送,详情请参考 实现离线推送

实现流程

发送静默推送

  1. 联系 ZEGO 技术支持配置携带静默推送策略的 resourceID。静默推送策略有 iOS 和 FCM 两种。根据实际需求,您可以选择只携带一种静默推送策略的 resourceID

  2. 在需要发送离线推送的场景(如 呼叫邀请离线推送 等),向 ZIMPushConfig 的 resourceID 字段填入预先配置好的值,并根据具体业务场景的需要填入 payload 字段。

    Untitled
    pushConfig.resourcesID="联系 ZEGO 技术支持配置的 resourceID";
    pushConfig.payload = "填写需要的附加内容";
    
    1
    Copied!

3.完成上述步骤,即可向别人发送静默推送。

接收静默推送

App 在前台

通过实现 onThroughMessageReceived 事件来接收在线静默推送通知。

Untitled
ZPNsEventHandler.onThroughMessageReceived = (ZPNsMessage message) {
    // 处理在线静默推送通知
    String payload = message.extras['payload'] as String;
};
1
Copied!

iOS Android App 在后台、或者 Android App 被终止时

  1. 实现类似如下代码块所示的一个顶级非匿名函数(例如,不能是要求初始化的 class 方法)。

    Untitled
    // 注意:@pragma('vm:entry-point') 必须放在函数上,以表明它可以在 AOT 模式下直接从本机或 VM 代码解析、分配或调用。
    @pragma('vm:entry-point')
    Future<void> _zpnsMessagingBackgroundHandler(ZPNsMessage message) async{
        // payload 为发送时填写的 payload 字段内容
        String payload = message.extras['payload'] as String;
        // 当 App 在后台被终止时,可在 logcat 查看 print 打印内容
        print(payload);
    }
    
    1
    Copied!
  2. 在打开 App 时尽快调用 setBackgroundMessageHandler 方法传入上述函数,以便 Android App 在后台被终止时触发上述方法,接收离线静默推送通知。

    Untitled
    ZPNs.setBackgroundMessageHandler(_zpnsMessagingBackgroundHandler);
    
    1
    Copied!

完成上述步骤,即可接收来自他人的静默推送。

Previous

实现 VoIP 通知

Next

自定义通知图标