ios apns推送 离线锁屏语音播报
一、背景
公司正在研发的一款App,需要在进行消息推送时支持语音播报。 具体要求:
- 离线:App在用户未打开时,可收到消息推送
- 锁屏:用户在设备锁屏状态下,仍可收到消息推送
- 语音播报:收到消息推送时可同时进行语音播放
苹果的APNs消息推送, 支持在应用未打开及设备锁屏状态下收到推送。 而同时进行语音播报,则需要做一些特殊处理。 目前语音播报的场景有两种: 一种是固定音频的播放, 一种是需要动态合成后的音频播放。如支付宝或微信收款的消息提醒: “支付宝/微信成功收款100元” 。 基于以上两种场景,接下来会逐一分析。在分析之前,需要先对APNs做一个简单的了解。
二、认识APNs
APNs(英文全称:Apple Push Notification service),中文翻译为:苹果推送
通知
服务。
通知是由两个主要部分组成的数据:设备令牌deviceToken
和 payload
消息。
- 设备令牌
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
字典包含苹果用来向用户设备发送通知的keys
。key
指定了您希望系统在提醒用户时使用的交互类型
。
下表列出了包含在该字典中的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
本文来自博客园,作者:reyzhang,转载请注明原文链接:https://www.cnblogs.com/reyzhang/p/17352424.html