iOS App签名原理

首先,由于苹果的生产厂商生产的手机、电脑和他们的系统都是苹果公司出产的,所以每一款苹果手机的系统都是苹果公司给安装的。那么这个时候苹果就可以在系统里内置很多东西。iPhone手机上的公钥就是苹果安装系统的时候内置的。当我们点击 keychain 里的 “从证书颁发机构请求证书”,这里就本地生成了一对公私钥,保存的 CertificateSigningRequest 就是公钥,私钥保存在本地电脑里。那这对密钥是如何关联上的呢?是钥匙串访问帮我们关联上的。打开钥匙串访问,展开一个证书,会显示一个专用密钥。那个专用密钥就是私钥。除了Mac电脑上的这一对公钥、私钥,还有一对密钥。这一对密钥中私钥放在苹果服务器上,公钥内置在苹果手机上。

也就是说,整个签名过程包含3个角色。运用的是 非对称加密算法RSA

角色 密钥
Mac电脑 公钥M、私钥M
苹果服务器 私钥A
iPhone手机 公钥A

一、前期请求证书过程

我们在开发者网站中请求证书的时候,会将我们的公钥M(CSR)发送给苹果服务器。苹果服务器会用私钥A会对公钥M(CSR)进行一次SHA256加密。此时就会生成一个证书【包含公钥M及公钥M的HASH值】【这个加密过程即为签名】。这个证书苹果服务器会发送给你,从而存储在本地电脑。
注:这个代码签名的信息,即为Mach-O文件里的Code Signature

二、App安装到iPhone手机过程

Xcode【Mac电脑上】在安装App到iPhone手机的时候,会用私钥M对App进行一次签名。

签名过程:首先对App进行一次SHA256加密运算,获得App的HASH值。然后通过私钥M对HASH值进行一次加密。就生成了一个App的签名。

一个完整的App想要安装到手机上面,必须具备以下几个东西:

  1. App代码
  2. App的签名
  3. 证书

三、iPhone手机验证过程

首先,iPhone手机会用公钥A将App里的证书进行解密,判断证书是否合法,得到公钥M及HASH值。然后再用公钥M对App的签名进行解密,判断App是否合法。

四、完善流程

上面的过程只是保证了,开发者的认证和程序的安全性。由于iOS的程序都是从AppStore下载的,如果只有上面的验证过程,那么你只要申请一个证书,就可以安装在所有的iPhone手机上面。所以苹果在上面的基础上加了两个限制:
1. 限制苹果后台注册过的设备(UDID)才可以安装。也就是说证书能安装的设备有限制
2. 签名只能针对某一个App(AppID)

因为除了设备ID、AppID还有Push推送等权限苹果都要控制,所以苹果统一把这些权限生成了一个文件,叫权限文件【Provision Profile】,用来描述App签名的权限。这个权限文件,是需要通过签名去授权的。这个描述文件是在苹果的开发者网站生成的。Xcode选择开发者信息后,会嵌入到Xcode里。

有了这个描述文件,开发者才可以真机调试。我们在开发的时候,会遇到这种情况,别的电脑【开发者】也想编译、安装这个App,这个时候就需要把私钥M导出成p12文件给别的开发者。因为只有你有了p12【私钥M】,你才能对App进行签名。
注:p12【私钥M】,即为钥匙串访问,展开一个证书,显示的专用密钥

image.png

更详细的签名原理,请移步:

iOS App 签的名原理【腾讯Bugly】

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

推荐阅读更多精彩内容