Android 5.0双卡信息管理分析

Android5.0开始支持双卡了。另外,对于双卡的卡信息的管理,也有了实现,尽管还不是完全彻底完整,如卡的slot id,display name,iccid,color等,其设计思路竟然跟之前接触到的一个平台是一样的,都是同不同颜色来标识不同的卡,让用户一目了然,只是5.0的实现目前还局限在FW框架里,应用层的实现还没有,相信,等到5.1或者再之后的版本中,我们就可以在setting里看到对卡表示颜色、名称等进行设置的功能菜单啦。

下面进入正题,来分析Android5.0的双卡信息是如何来维护的:

1卡信息的存储

先说结论,5.0是将所有卡信息通过数据库进行保存的。数据库表URL:content://telephony/siminfo,对应到的数据库为telephony.db中的siminfo表,代码文件在TelephonyProvider.java,在这里可以看到createTable的详情,来看看这个表都包含哪些字段。

总共设计了11个字段,下面这张图是从5.0模拟器上拉出来的telephony.db里截取到的,可以用来做示例:

表名:

表数据示例:

下面分别介绍一下这些字段的含义。


1.1 _id

这个自不必说,android里的每个db都有的,是数据库里的数据主key,这里的_id值也是以后代码里看到的subId,是在数据库中保存时所在的条目的唯一标识。有多少条数据,就说明保存了多少个sim卡的信息;

1.2 icc_id

从卡上读取得到,是卡的唯一身份标识,世界上的所有sim卡,每个卡都有不同的iccid,就像身份证一样;如上面图中的16进制串89014103211118510720;

1.3 sim_id

分配给卡的id序号,android设计从0开始,最大为卡槽个数,比如如果是双卡终端,那么只有可能是0或者1;当然无卡时其值为-1,所以这里其实是与卡槽固定对应的,卡槽如果有卡就取对应id,如果无卡,就设为-1;

1.4 display_name

分配给卡的显示名字,从代码上来看开机后会尝试使用运营商名字,如果取不到,就使用简单的SUB 01这样的字串表示,等拿到运营商名字之后重新set,另外从下面的name_source字段的设计来看,android是允许用户来自己指定这个显示名的;

1.5 name_source

表明display_name字段的来源,有两种来源,一是系统自动,name_source取值为0,另一种就是来自用户指定,取值为1;

1/**

2 *The name_source is the default

3 *@hide

4 */

5publicstaticfinalint NAME_SOURCE_DEFAULT_SOURCE =0;

6

7/**

8 *The name_source is from the SIM

9 *@hide

10 */

11 publicstaticfinalintNAME_SOURCE_SIM_SOURCE =1;

12

13 /**

14 * The name_source is from the user

15 * @hide

16 */

17 publicstaticfinalintNAME_SOURCE_USER_INPUT =2;

1.6 color

显示颜色,将使用颜色在UI上明显区分卡1和卡2;android设定每个卡都只能从固定的几个颜色中取,如下:

1/** @hide */

2publicstaticfinal String COLOR ="color";

3

4/** @hide */

5publicstaticfinalint COLOR_1 =0;

6

7/** @hide */

8publicstaticfinalint COLOR_2 =1;

9

10 /** @hide */

11 publicstaticfinalint COLOR_3 =2;

12

13 /** @hide */

14 publicstaticfinalint COLOR_4 =3;

15

16 /** @hide */

17 publicstaticfinalint COLOR_DEFAULT =COLOR_1;

这四种颜色根据主题是dark还是light分别对应4种颜色,这些颜色其实并非是色值,而是固定颜色的背景9.png图片,都定义在资源drawable里,看来是用来做backgroud用的。如

sim_dark_bluesim_light_purple

其他几种颜色可以参考SubscriptionController. setSimResource函数里去color资源数组的初始化。

1.7 number

该卡对应的号码,phone number。//TODO:研究一下这个是怎么获取到呢?

1.8 display_number_format

标识number字段的格式,总共有固定的3种,取其一。

/** @hide */

publicstaticfinalint DISPLAY_NUMBER_NONE=0;

/** @hide */

publicstaticfinalint DISPLAY_NUMBER_FIRST=1;

/** @hide */

publicstaticfinalint DISPLAY_NUMBER_LAST=2;

/** @hide */

publicstaticfinalint DISLPAY_NUMBER_DEFAULT= DISPLAY_NUMBER_FIRST;

从SubscriptionController. setDisplayNumberFormat()函数的注释可以看出点门道,

*Set number display format. 0: none, 1: the first four digits,2: the last four digits

但搜了一下,对应的setDisplayNumber()函数并没有跟这个format有关联,直接保存传入的number到数据库了。所以还不太清楚the first four digits和the last four digits的具体含义,等以后android应用层完善后应该能看到具体的使用方式。

1.9 data_roaming

是否允许这张卡进行数据漫游,默认禁止漫游。

1 /** @hide */

2 publicstaticfinalint DATA_ROAMING_ENABLE=1;

3

4 /** @hide */

5 publicstaticfinalint DATA_ROAMING_DISABLE=0;

6

7 /** @hide */

8 publicstaticfinalint DATA_ROAMING_DEFAULT= DATA_ROAMING_DISABLE;

1.10 mcc

移动国家码,从卡上读取得到,卡的mcc码;

1.11 mnc

移动网络码,从卡上读取得到,卡的mnc码。度娘到对于mcc和mnc的解释:

MCC是Mobile Country Code的缩写,译为移动国家代码。它由三位数字组成。用于标识一个国家,但一个国家可以被分配多个MCC。比如美国的MCC有310,311,和316。中国的MCC只有460。MNC是Mobile Network Code的缩写,译为移动网络代码。它由二到三位数字组成。MNC和MCC合在一起唯一标识一个移动网络提供者。比如中国移动的MNC是00,中国联通的MNC是01,中国联通CDMA的MNC是03,中国卫星全球星网的MNC是04。因此,460 00就唯一标识了中国移动。

所以卡的displayname应该也是通过mcc+mnc得到的。

2主要工作类

上面介绍了卡信息的数据设计,接下来看看有哪些类围绕着这些数据来对外提供接口和功能。

功能介绍

TelephonyProvider

siminfo数据库provider,直接操作DB,实现siminfo表的增删改查。

SubscriptionController

实现为远程service,在phone初始化时被创建,作为数据库的对外接口提供功能,其内部维护从数据库读取到的siminfo list,并实现了大量的如getSubId

getDisplayName setDisplayName等getter和setter方法,这些方法维护siminfo

list以及通过URL访问数据库来实现功能。

SubscriptionManager

该类所有的内部接口都实现为了static,也就是该类是一个纯粹提供接口的静态类,其内部并不实现具体的逻辑,只是通过调用SubscriptionController这个service的对应接口来完成工作,所以该类是一个对外接口的封装,APP可以直接通过SubscriptionManager.getSubId等来实现功能,不需要直接操作service。目前还是Hide的,估计以后会开放给SDK。这种设计模式,android FW层用的很多,如SmsMnager、TelephonyManager等。

SubInfoRecordUpdater

卡信息变化的监听者和更新者,其在PhoneFactory中创建完phones之后被创建,起来之后会注册对ACTION_SIM_STATE_CHANGED的监听,收到监听之后更新对应siminfo的信息,如iccid、displayname(运营商名)、phonenumber。并且在自己内部维护了每个卡的卡状态,这里的卡状态区别与ACTION_SIM_STATE_CHANGED所携带的卡状态,ACTION_SIM_STATE_CHANGED的卡状态有LOCKED、READY、NOT READY、ABSENT等,是指的卡的具体状态,而这里的卡状态是指有没有插卡、该卡槽的卡是不是变过了(换了一张卡)、卡槽的卡是一张没见过的新卡、卡槽的卡是位置互换啦、卡槽的卡没变化。【状态还真有点绕,管的挺多的啊。。。】这些状态是在收到ACTION_SIM_STATE_CHANGED之后,根据卡状态以及卡的iccid等一些信息算出来的,如果发现有新卡插入会进行广播。

SubInfoRecord

subinfo的可序列化实现,封装数据库数据。

另外,在代码中还可以看到Subscription和SubscriptionData这两个类,这两个其实只是数据封装,并不直接跟卡信息管理相关,其只是保存了一些卡的数据来提供给phone等使用,目前还找不到组织他们的接口,全局搜索会发现,好多地方google都注释掉了,逻辑还没完整。SubscriptionData是Subscription list,目前从代码来看,这两个还没有真正用起来,所以可以先无视了,不过要吐槽下google的代码,起名咋这么绕啊。另外还有个CdmaSubscriptionSourceManager的类,这个是跟CDMA的卡提供者信息有关的,会影响到具体的网络行为,也跟本文的双卡信息管理无关。

3工作流程

通过上面主要类的介绍,基本上整个双卡信息管理的框架就出来了,画了一个图方便理解。


4总结

5.0通过DB来保存和维护双卡信息,SubInfoRecordUpdater通过监听卡的变化动态更新数据库里的卡数据;SubscriptionController和SubscriptionManager通过各种接口来向外提供卡信息的查询和修改,这样看来逻辑还是比较清晰明了的


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

推荐阅读更多精彩内容