iOS代码签名机制分析(2)分析

第一篇文章的最后,简单描述了iOS系统使用数字签名的机制。本质上就是使用RSA+信息摘要算法为基础的签名技术来对代码和图像素材资源进行签名验签。文章的最后提出了两个问题:
**
(1)RSA的公钥和私钥从何而来?
(2)iOS设备如何保证该公钥和私钥合法性,并有权限对代码进行签名和验签操作?
**
我们通过申请苹果开发者证书,生成描述文件,生成ipa包等过程的详细描述,来说明一下以上问题如何解决。

1,申请苹果开发者证书。

使用KeyChain工具,生成certificateSigningRequest.CertSigningRequest。
操作步骤:“钥匙串访问” -> “证书助理” -> “从证书颁发机构请求证书” -> “用户电子邮件地址填写:apple id;常用名称写得形象一点。”->“请求是选择存储到磁盘”

保存在本地的就是certificateSigningRequest.CertSigningRequest文件了。如何查看这个文件的内容呢?有两种方法,第一种是使用苹果的keyChain(钥匙串访问),查看密钥。第二种是使用openssl的命令行工具。

//查看certificateSigningRequest.CertSigningRequest的方法
openssl asn1parse -i -in CertificateSigningRequest.certSigningRequest

总结以上步骤的产物:
**
a,生成私钥和公钥对。
b,指明使用加密和签名算法(RSA+SHA1)。
**
最后,certificateSigningRequest.CertSigningRequest = 加密后信息+公钥+加密方法和摘要方法。
我们就得到了,可以和苹果交互并认证的RSA的密钥对了,那么接下来的问题就是如何保证我们与苹果之间所使用的密钥对不被别的中间人所攻击或者替换呢?

2, 上传certificateSigningRequest.CertSigningRequest文件到苹果开发者网站,苹果处理后下载开发者证书。

这里,将certificateSigningRequest.CertSigningRequest上传的步骤保证了,你的公钥信息准确的提交给了苹果。首先,你需要有苹果的开发者账号,登录到上传certificateSigningRequest.CertSigningRequest的界面;其次,信息摘要和签名技术保证了你上传公钥的完整和有效性。因此,这个步骤保证了你的公钥被安全准确的送到了苹果的手中。苹果通过验证苹果自己在Mac主机里面的公钥(苹果公钥,非上面步骤生成),来保证你的请求是合法有效的,同时,苹果生成数字证书,对你的公钥进行了认证。

3,导入开发者证书。

双击证书后,系统导入到keyChain工具里,可以直接在keyChain(钥匙串访问)里面查看,还可以使用openssl查看证书内容:

openssl x509 -inform der -in ios_development.cer -noout –text

通过查看证书的内容,我们发现,苹果做的事情仅仅就是将我们的公钥原封不动的打包到证书里面,再交还给我们导入到KeyChain进行管理。苹果的这个流程,就是对我们公钥的一个认证。

当我们的程序写好的时候,进行程序打包的过程时。我们自己手上掌握的私钥,会将程序代码和其它文件资源,使用私钥加密。

4,真机调试。

好了,现在打包好的程序就要进入真机调试了,真机如果要验证我们的代码和程序合法且有权限在真机运行,需要什么呢?请读者在这里想一下。

好了,首先,就是需要公钥进行验签操作。从苹果下载的证书,就是认证后的公钥,需要放在描述文件里面,打包进入真机。此外,描述文件除了证书外,还有AppID、功能授权列表、设备列表、苹果签名等信息,对App在设备中的能力和权限做出有效的规定。
iOS程序最终都会以.ipa文件导出,先来了解一下ipa文件的结构:

事实上,ipa文件只是一个zip包,可以使用如下命令解压:

/usr/bin/unzip -q xxx.ipa -d <destination>

解压后,得到上图的Payload目录,下面是个子目录,其中的内容如下:
(1) 资源文件,例如图片、html、等等。
(2) _CodeSignature/CodeResources。这是一个plist文件,可用文本查看,其中的内容就是是程序包中(不包括Frameworks)所有文件的签名。注意这里是所有文件。意味着你的程序一旦签名,就不能更改其中任何的东西,包括资源文件和可执行文件本身。iOS系统会检查这些签名。
(3) 可执行文件。此文件跟资源文件一样需要签名。
(4) 一个mobileprovision文件.打包的时候使用的,从MC上生成的。
(5) Frameworks。程序引用的非系统自带的Frameworks,每个Frameworks其实就是一个app,其中的结构应该和app差不多,也包含签名信息CodeResources文件

验证一个ipa是否合法关键的几个点:
(1) 解压ipa
(2) 取出embedded.mobileprovision,通过签名校验是否被篡改过。
(3) 校验所有文件的签名,包括Frameworks。
(4) 比对Info.plist里面的BundleId是否符合embedded.mobileprovision文件中的AppID。

整个过程除了技术支持(RSA+摘要算法+数字证书),还有安全流程管控(苹果开发者账号,上传公钥,苹果控制发布数字证书,认证公钥,且保证公钥合法准确)。整个机制设计,环环相扣,苹果做到对APP在真机运行和调试的有限管控。

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

推荐阅读更多精彩内容