苹果通知中心服务ANCS协议分析二

相关文章:
苹果通知中心服务ANCS协议分析
低功耗蓝牙BLE介绍

jiesean摄

IOS设备的ANCS服务是为了周边设备通过低功耗蓝牙获取实时通知而产生的机制,它实际上是ble gatt协议的一种封装。

本人作为android开发者,对ios的开发一窍不通,但是android从4.3开始也提供了对于ble的支持,这给了我们一种ios设备与android设备互联的可能,此文重要针对发现ANCS和从ANCS中获取ios通知的过程中的几个重要的问题做出说明。

区分GAP和GATT中定义的角色的不同

  1. 首先GAP中定义了两种角色,一种是中心设备,主要以ios设备为主;二是周边设备,以小型的低功耗设备为主,比如iwatch、各种手环等,他主要是从连接的层面下的定义,即中心设备可以同时连接不同的周边设备,而一个周边设备只能连接一个中心设备。
  2. 而对于GATT来说,他是基于c/s模型的,因此它又一个server和client的区分,保持有service和characteristic的为server,而连接上server去读写这些characteristic的为client。

不能想当然的认为中心设备等同于server,周边设备等同于client,他们是不同层面的东西。以两个不同的生活场景进行举例说明:

  • 手环中的传感器获取人的运动状态以及身体数据,ios设备从手环中获取这些基础的数据来进行进一步的处理和分析。这个场景中手环是提供数据者,ios设备从中获取设备,因为此时,ios是client,手环是server。
  • iwatch等智能手表,可以同步ios设备的短信和来电等,此时数据的提供者是ios设备,而智能手表则作为数据获取者,此时ios是server,而智能周边设备则是client.

发现和绑定ios设备

如果有了ANCS的基本的知识,我们知道ANCS其实是基于ble gatt协议的,而ANCS扮演的就是gatt协议中的gatt server中的一个service,我们想要获取该service中的内容的话需要gatt client先扫描到该设备,然后连接上gatt server就可以读写其中的service和characteristic来获得信息。

但是根据官方提供的ble gatt client的api实现简单的应用的话,发现能够扫描到很多的ble设备,但是始终无法扫描到ANCS这个服务,这是什么原因呢?莫非ios设备没有打开该服务?
其实并不是这样的,只要ios设备的蓝牙打开后,ANCS就会不停的发送广播告之周围的gatt client。

那么既然ANCS打开了我们为什么扫描不到呢?
原因是IOS对与ANCS服务做了特殊的限制,只有同ios设备进行连接和绑定的设备才能后发现ANCS.

ios蓝牙的限制我们都知道,那么如何才能够同ios设备进行连接和绑定呢?
这里我给出的解决方案是:

  1. ios设备上需要虚拟一个ble周边设备。可以通过调用gatt server的api自己实现app,或者下载lightblue。
  2. 扫描到ios设备上的自己虚拟出来的周边设备后,跟该设备绑定。
//android提供的代码如下:
BluetoothDevice device;
device.createBond();
  1. 连接到该设备
device.connectGatt(getApplicationContext(), false, mGattCallback);
  1. 连接成功后,就能够获得ANCS service了
BluetoothGattService ancsService = gatt.getService(UUID.fromString(Constants.service_ancs));

ANCS的操作

这个在苹果通知中心服务ANCS协议分析这篇文章中已经做了详细的描述,这里只是简单的梳理一下:

获取通知的基本的信息:

订阅Notification Source特性,可以在Notification Source特性中读取通知的基本信息。

  • 通知的事件类型(增删改三种),很容易理解,ios设备产生了通知就是add;ios设备上查看了该通知,就会产生一个remove事件。
  • 通知的事件标志:可以从这个参数中看出ios设备给出的通知级别,以及可以对该通知执行的动作(这个稍后详解)。
  • 通知的范畴或者翻译做种类?总之就是告诉你是个什么通知,比如是消息,来电,未接来电,邮件,新闻等,总共定义了12种。
  • 该种类通知的活跃数量:就是几条未接来电啊之类。
  • UID:该通知的唯一标示。
获取通知的详细信息:

首先订阅 Data Source特性,然后往 Control Point中写入获得通知属性的命令,然后在 Data Source中读取通知详细信息的数据包。
写入命令的格式的示例,当然可以获得属性不止这些:

byte[] getNotificationAttribute = { 
    //规定为0 
    (byte) 0x00, 
    //UID,通知的id 
    uid[0], uid[1], uid[2], uid[3], 
    //title,Attribute 1,第一条属性,通知的标题 
    (byte) 0x01, (byte) 0xff, (byte) 0xff, 
    //message,第二条属性,标题的消息 
    (byte) 0x03, (byte) 0xff, (byte) 0xff
};

Data Source中读取的数据包格式


前面文章中有说到这个数据包的长度如果超过最大长度就会被分为多段发送,这个最大长度经亲测为20byte。
而为了最大的有效信息的传输,除了第一个分段中包含commandID,Notification这两个重要的标示信息外,后面的分段并不包含这些,而是直接跟数据信息,也就是说你把拿到的所有分段直接组合起来就是完整的数据包,但是那个分段是最后的结束分段要通过参数的长度进行计算。

对通知执行特定的动作:

很容易理解,我们使用智能手表可以代接ios的消息,手表查看后,ios中的该信息的通知消失,这个消失的动作就是针对消息型通知的特定动作;而对于来电而言,就可以有接听来电和拒绝接听两种操作。
ANCS将特定动作分为negative action和positive action,但这里有两个问题需要特别注意:

  • 特定动作是NC请求NP去执行的,也就是说,动作是在NP上面执行。
  • negative action和positive action对于不同类型的通知代表的含义是不同的,比如negative action对于来电就是拒绝接听,而对于信息类型来说就是删除通知。
  • 并不是每一个通知都可以执行这两种动作,比如消息类型的通知就只能执行negative动作,具体NC能够去请求执行哪些动作,NP会告知你,下面进行详解。

前面获取通知的基本的信息这一节中基本信息的第二项是事件标志位eventFlags,它占一个字节,也就是8bit,这8bit每一位都表示一种属性。

EventFlagSilent = (1 << 0),
EventFlagImportant = (1 << 1),
EventFlagPreExisting = (1 << 2),
EventFlagPositiveAction = (1 << 3),
EventFlagNegativeAction = (1 << 4),
Reserved EventFlags = (1 << 5)–(1 << 7)

由此可知,我们可以通过查看其第4、5位是否为1来判断该通知可以执行什么动作。

暂时想到这些,想到再补。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,076评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,658评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,732评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,493评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,591评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,598评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,601评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,348评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,797评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,114评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,278评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,953评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,585评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,202评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,180评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,139评论 2 352

推荐阅读更多精彩内容