iOS调试技巧

IPA重签名的那些事

2016-03-17  本文已影响2014人  tom510230

这两天终于彻底搞定了ipa签名的问题,整理一下作为总结

打包流程

IPA打包.png

超好用的resign脚本

之前搜索了一个很简单的resign脚本,跟这里描述的做法差不多《iOS ipa重签名》。然而在签我们的ipa的时候却发生失败,仔细看了一下,原来是因为我们的ipa是启用了push notification的,需要用到entitlement,然而这个文件在xcode工程中是找不到的。后来又找到了一篇更实用的文章《iOS的ipa重签名》,里面提到的fastlane/sign脚本能够解决在签名时遇到的各种问题,只要mobileprovision文件和p12文件是对应得上,并且证书名称没有写错,就绝对没有问题了。脚本的核心技术在于使用了PlistBuddy来解析plist文件里面的信息并做处理,脚本的核心代码在这一行

/usr/bin/codesign ${VERBOSE} -f -s "$CERTIFICATE" --entitlements="$TEMP_DIR/newEntitlements" "$APP_PATH"

关于Entitlements

Entitlements其实是一个配置文件,对于一些要开启的app功能,需要使用Entitlements文件来做配置。Entitlements文件管三个东西:iCloudpush notificationApp沙盒(iosapp沙盒是自动配置的,并不需要Entitlements,所以这里实际上是指mac下的app沙盒)。官方文档地址如下:https://developer.apple.com/library/mac/documentation/Miscellaneous/Reference/EntitlementKeyReference/Chapters/AboutEntitlements.html

关于p12和mobileprovision

在平常用xcode开发的时候,我们经常会被两个东西卡住Code Signing IdentityProvisioning Profile。其实这两个设置项对应的就是p12文件和mobileprovision文件。按照苹果官方的说法,正确的理解应该是这样:

综上,那为什么p12mobileprovision是怎样对应上的呢,就是因为mobileprovision里面含有了p12文件的publickey

总结一下:app打包的时候,通过mobileprovision文件来对代码进行签收,通过p12文件完成加密过程,p12文件和mobileprovision文件通过publickey可以一一对应

关于证书

苹果的证书类型共有三种

MoreAPNs是用Http2.0协议来工作的,非常时髦

上一篇 下一篇

猜你喜欢

热点阅读