ios apns推送 离线锁屏语音播报

一、背景

公司正在研发的一款App,需要在进行消息推送时支持语音播报。 具体要求:

  • 离线:App在用户未打开时,可收到消息推送
  • 锁屏:用户在设备锁屏状态下,仍可收到消息推送
  • 语音播报:收到消息推送时可同时进行语音播放

苹果的APNs消息推送, 支持在应用未打开及设备锁屏状态下收到推送。 而同时进行语音播报,则需要做一些特殊处理。 目前语音播报的场景有两种: 一种是固定音频的播放, 一种是需要动态合成后的音频播放。如支付宝或微信收款的消息提醒: “支付宝/微信成功收款100元” 。 基于以上两种场景,接下来会逐一分析。在分析之前,需要先对APNs做一个简单的了解。

二、认识APNs

APNs(英文全称:Apple Push Notification service),中文翻译为:苹果推送通知服务。

通知是由两个主要部分组成的数据:设备令牌deviceTokenpayload消息。

  • 设备令牌deviceToken: 是类似于一个电话号码。它包含的信息,使的APN定位到设备上安装的客户端应用程序。APN还用它来验证通知的路由。
  • payload消息:是一个JSON定义的属性列表中指定的设备上的应用程序的用户将被提醒。

2.1 工作步骤

  • 首先,APNs会对用户进行物理连接认证,和设备令牌认证(简言之就是苹果的服务器检查设备里的证书以确定其为苹果设备);
  • 然后,将服务器的信息接收并且保存在APNs当中,APNs从其中注册的列表中查找该IOS设备并将信息发送到该设备;
  • 最后,设备接收到数据信息给相应的APP,并按照设定弹出Push信息。

参考如下顺序图,会更易理解:

2.2 payload 消息JSON结构

{
    "aps" : {
        "alert" : {
            "title" : "Game Request", // 标题
            "body" : "Bob wants to play poker", //内容
        },
        "badge" : 5, //角标
        "sound" : "binggo.caf", //声音
        "content-available" : 1,
        "mutable-content" : 1, //可变内容
    },
}

注意: payload 最大不能超过256字节

aps字典包含苹果用来向用户设备发送通知的keyskey指定了您希望系统在提醒用户时使用的交互类型
下表列出了包含在该字典中的keys以及每个key的信息类型。注意:非苹果给定的key会被忽略。

值的类型 描述
alert Dictionary or String 当您希望系统显示标准警报或横幅时,请包含此键。用户设备上应用程序的通知设置决定是否显示警报或横幅。该key的首选值是字典 。字典的更多关键字请参阅 Table 9-2。 如果指定字符串作为该键的值,则该字符串将显示为警报或横幅的消息文本。
badge Number 当您希望系统修改应用程序图标的角标时,请包含此键。如果字典中没有包含此键,则Badge角标不会更改。若要删除角标,请将此键的值设置为0
sound String 当您希望系统播放声音时,请包含此键。此键的值是应用程序main bundle 或应用程序数据容器的Library/Sounds文件夹中声音文件的名称。如果找不到声音文件,或者为该值指定了default,系统将播放默认警报声音。有关为通知提供声音文件的详细信息;请参阅自定义警报声音
content-available Number 设置此键的值为1,以配置后台更新通知。当此key存在时,系统会在后台唤醒您的应用程序,并将通知发送给其应用程序代理。有关配置和处理后台更新通知的信息,请参阅配置后台更新通知
category String 为该键提供一个表示通知类型的字符串值。此值对应于应用程序的某个注册类别的identifier属性中的值。要了解有关使用自定义操作的更多信息,请参阅配置类别和可操作通知

三、固定语音的推送方案

四、合成语音的推送方案

4.1 Notification Service Extension 通知服务扩展 介绍

4.2 Notification Service Extension项目中的使用

4.3 iOS12之前的方案

4.4 iOS12之后的方案

更多内容详见:https://blog.csdn.net/zhanglei5415/article/details/130316253

热门相关:骑士归来   寂静王冠   战神   横行霸道   横行霸道