苹果双向验证

背景知识介绍

​ base64 编码方案,是一种基于64个可打印字符来表示二进制数据的方法

​ HASH (散列函数)

​ MD5算法

​ SHA1/512

​ HMAC :使用KEY进行明文加密,然后进行2次 hash。key从服务器获取,对应一个账号一个key,

​ 随机生成保存服务器。

​ 特点:算法公开

​ 对相同的数据加密,得到的结果是一样的

​ 对不同的数据加密,得到的结果是定长的。如:md5 32个字节

​ 不可逆

​ 信息摘要,信息指纹。使用来做数据识别

​ MD5举例 www.cmd5.com,反向查询,解决方案 密码加盐(默认在用户密码后面添加一串

​ 乱七八糟的字符串)

​ 加盐会有泄露风险,salt泄露了 还是可以通过大数据反向查询出来,HMAC动态盐加密方案

​ 对称加密算法 DES 、3DES、 AES(高级密码标准)、RC-5、IDEA:加密解密都是同一个秘钥

​ 非对称加密算法 RSA、 ECC (公钥加密 私钥解密,私钥加密 公钥解密)

数字证书&数字签名

证书,通过证书颁发机构私钥对需要认证的公钥和一些相关信息加密形成证书文件“数字证书”

p12文件,带有私钥的证书 = 证书 + 私钥 ,所以可以通过导出并且安装到别的设备上

数字签名 = 内容Hash值 + RSA加密

经典图解 数字证书和数字签名

苹果双向验证原理图解

参考iOS App 签名原理

1.验证App是否经过苹果认证,见图

2.如何控制App安装问题,见图

其他形式的发布签名验证

另外两种方式 In-House 企业签名和 AD-Hoc 流程也是差不多的,只是企业签名不限制安装的设备数,另外需要用户在 iOS 系统设置上手动点击信任这个企业才能通过验证。

而 AppStore 的签名验证方式有些不一样,苹果在后台直接用私钥签名 App 就可以了,实际上苹果确实是这样做的,如果去下载一个 AppStore 的安装包,会发现它里面是没有embedded.mobileprovision文件的,也就是它安装和启动的流程是不依赖这个文件,验证流程也就跟上述几种类型不一样了。

据猜测,因为上传到 AppStore 的包苹果会重新对内容加密,原来的本地私钥签名就没有用了,需要重新签名,从 AppStore 下载的包苹果也并不打算控制它的有效期,不需要内置一个embedded.mobileprovision去做校验,直接在苹果用后台的私钥重新签名,iOS 安装时用本地公钥验证 App 签名就可以了。

解决的问题

1.为什么换台设备,直接从开发者中心下载证书,不能实现真机打包调试,必须要通过导出p12文件到新设备上。

答:签名是通过 p12中的私钥去签的,开发者中心只能下载证书,证书中只有公钥,没有私钥。

2.苹果如何保证app是可信任的。

答:验证App是否经过苹果认证,通过2次解决认证问题

3.如何控制App的安装。

答:苹果发明了 provision profile文件格式,其中的entitlements,uuid,设备ID,appid等去控制一个app是否能被安装及调试等。

4.知道原理之后,回头看看重签名。

实质上 就是需要替换provision profile文件,以及安装时候需要校验的信息,比如bundleID,重新签名即可。

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

推荐阅读更多精彩内容