iOS-签名机制和证书原理

原文发表在个人博客iOS-签名机制,转载请注明出处。

本文主要介绍iOS系统的签名机制和证书原理。

对称和非对称加密

对称加密:加密和解密用的是同一份密钥。

非对称加密:加密和解密用的是不同的密钥,称为公钥和私钥。

iOS 系统采用的均是非对称加密。

App Store下载的签名机制

当 App 提交审核通过后,Apple 会对 App 进行重签名。因此,从 App Store 下载的 App ,统一都是苹果的官方签名。验证机制也较为简单。

  1. Apple 官方保存着私钥,在App提交审核通过后,会通过私钥对其进行重签名;
  2. iOS 系统内置公钥,用户从 App Store 下载 App ,iOS 系统通过公钥对其进行签名验证;
  3. 验证通过,则说明该 App 是经过苹果认证的,未经篡改的,允许运行,否则,拒绝运行。
iOS-Signature-Normal

XCode开发的签名机制

在 XCode 中开发时,用的是开发证书。需要针对不同的开发者账号进行验证,签名机制较为复杂。

开发者身份验证

在 Apple Developer 生成证书时,为了验证开发者身份,需要在本地 keychain 中生成公私钥,公钥保存在 CertificateSigningRequest 文件中,上传到 Apple Developer ,私钥如果需要给其他开发者用,可以导出为 .p12 文件。

生成证书

Apple Developer 后台接收到开发者公钥后,利用 Apple 的私钥对其进行签名,生成证书cer。

验证设备

除了验证开发者身份,还需要验证 AppID 和设备的 UUID , 权限控制 Entitlements 等,把这些信息和上面生成的证书一起,再用 Apple 的私钥进行一次签名,生成最终的 mobileprovision 文件。

iOS-Signature-MobileProvision

签名 App

在XCode编译后,生成 App 文件时,会对其通过开发者私钥进行签名,将 mobileprovision 文件命名为 embedded.mobileprovision 并将其打包到 App 文件中。

在通过开发者私钥签名 App 时,对于可执行文件( Mach-O ),会将签名直接写入到该文件中,而对于其他的资源文件,会统一写到 _CodeSignature 文件下的 CodeResources 文件中。

iOS-Signature-App

CodeResources 文件的格式:

iOS-Signature-CodeResource

验证签名

在安装 App 文件时,首先通过 iOS 系统内置的 Apple 公钥对上面的签名进行验证,包含开发者共私钥匹配,设备 ID,App ID,权限控制 Entitlements ,证书有效期验证等。

iOS-Signature-Developer

看了又看:
深度学习是怎么识别人脸的?
300行代码实现手写汉字识别
如何在一周内做一款拼音输入法
iOS-线程同步详解

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 接触iOS开发多年,花了一点时间去研究了一下iOS这套证书和签名机制,并撰文分享给需要的朋友。由于本人才疏学浅,多...
    风和花阅读 5,920评论 0 7
  • 非对称加密和摘要非对称加密的特性和用法非对称加密算法可能是世界上最重要的算法,它是当今电子商务等领域的基石。简而言...
    哈哈哈我的简书账号阅读 5,077评论 1 5
  • 原文地址 非对称加密和摘要 非对称加密的特性和用法 非对称加密算法可能是世界上最重要的算法,它是当今电子商务等领域...
    独酌丿红颜阅读 4,765评论 0 7
  • 从事iOS开发三年了,日常的精力主要放在公司的业务上,最近决定开始写一些技术方面的东西,记录自己今后的学习历程,也...
    差一点不是帅哥阅读 5,714评论 0 8
  • 千辛万苦走到你身边,粉身碎骨都走不到你的心,下辈子我转世做你,你做我。我一定会好好珍惜,不让你奔波疲惫,心力交瘁,...
    甘草薄荷阅读 1,562评论 0 0

友情链接更多精彩内容