iOS App研发的最后冲刺:内测与部署

CSDN移动将持续为您优选移动开发的精华内容,共同探讨移动开发的技术热点话题,涵盖移动应用、开发工具、移动游戏及引擎、智能硬件、物联网等方方面面。如果您想投稿、参与内容翻译工作,或寻求近匠报道,请发送邮件至tangxy#csdn.net(请把#改成@)。

当开发者历经磨难、披荆斩棘,完成了一个iOS项目后,最后的临门一脚就是应用的内测、部署。那么,在这最后的射门动作中,都有哪些地方需要开发者注意?有哪些方式能够更好地帮助我们进行iOS应用的发布部署?

本文针对iOS App开发的最后阶段来详解如何在真机上进行调试,将App发送给其他测试人员进行内测,以及内测完成后如何将App上传至App Store进行应用审核,针对苹果账号的类型、真机调试、打包与崩溃收集进行深度剖析。

苹果账号的类型

苹果开发者计划分为个人、公司、企业和教育开发者四个类型。个人开发者证书费用为$99一年,该账号在App Store销售者只能显示个人的ID。并且,个人账号只能有一个开发者,100个苹果的iOS设备UDID测试。

公司开发者费用为$99一年,该账号在App Store销售者可以显示类似Studios,或者自定义的团队名称。公司账号可以允许多个开发者协作开发,比个人多一些帐号管理的设置,可以设置多个Apple ID,分4种管理级别权限,100个苹果的iOS设备UDID测试。但是,申请时需要填写公司的邓白氏编码(D-U-N-S),D-U-N-S邓白氏码可以在 苹果官方网站免费申请。

企业开发者账号费用为$299一年, 该账号开发应用不能发布到App Store,只能企业内部应用,苹果的iOS设备UDID数量不限制。企业账号适合不希望上线App Store,但是需要企业内部,比如1000人的iOS设备都部署。

特别需要注意的是,其他渠道提供的所谓的企业证书实际上是与他人共用一张企业证书,苹果会侦测到这种情况,并进行封号处理。封号后,包括已经使用该证书安装了的App都会无法继续使用。

这些开发者账号的申请都需要一个重要的条件,那就是有一张支持Visa或MasterCard的信用卡。

真机调试

使用真机调试,必须要使用开发者证书,以及正确填写App ID,配置好Provision Profile,具体流程如下:

安装调试证书; 填写App ID; 根据App ID填写Provision Profile ,并下载安装到Xcode; 真机调试运行。 怎样申请开发者证书?

需要下列几步:

1. 请求CSR文件

2. 创建调试证书

3. 双击安装

可以看到钥匙串中有了我们刚安装的证书,左侧有个三角,点击展开可以看到证书私钥,如果没有私钥,则证书是不可用的。一般这种情况是你在开发者网站上下载了其他Mac上制作的证书,可以从这台Mac导出证书安装到自己的电脑上。

创建App ID

1. 填写App ID Name

2. 支持推送、Game Center等功能的话,不能创建含有通配符*的AppID,所以这里我们选择Explicit App ID。

3. 勾选需要的服务,然后Continue。

添加设备

1. 填写设备名称、设备UDID

2. Register

注:最多添加100台设备。创建Provisioning Profile

1. 选择App ID

2. 选择证书

3. 选择设备(只有Development、AdHoc需要选择设备)

4. 填写Profile Name

5. 点击Download下载,双击安装到Xcode。

XCode打包

Configurations

默认Configurations包含两个配置:Debug、Release,可以看到Build Setting里好多配置都区分了Debug、Release,可以根据不同的情况配置不同的选项,最常用的就是根据真机调试、打包发布,分别在Debug、Release选择合适的证书、Profile。

个人认为,现在的Xcode不用在Duplicate Release配置来建立专门打包App Store、Adhoc或其他的Configuration,因为并不会方便多少,只是省去了选择证书,但是还得设置Archive选项。

一般来说,Adhoc、AppStoreInhouse,二者用的都是同一个证书,只是Profile不同而已,简单的选择一下Profile,是不是更省事一些呢。

指令集

先说一下iOS设备的指令集:

arm64

armv7s

armv7

armv6

如上图所示,Architectures支持的指令集为armv7、arm64,Valid Architectures支持的指令集为armv7、armv7s、arm64,这时只会生成一个armv7、arm64指令集的二进制包。

注意:许多用户可能会发现自己的应用安装不了,这时候可以看看自己的App支持的指令集,遇到过几个用户的指令集只支持arm64,这样的App在设备不是arm64的情况下是安装不了的。 Code Signing

上图中Code Signing Identity包含的Debug和Release两项,其中,Debug指选择真机调试证书,Release指选择发布证书(AdHoc、AppStore/Inhouse打包都使用发布证书)。而在 Provisioning Profile中,无论真机调试,还是发布App,选择的Profile的App ID要与项目工程的BundleId匹配。

注意:Provisioning Profile的Release这里选择的Profile,并不一定就是签名ipa用的Profile,后面会讲到。导出ipa

导出ipa首先需要选择ipa版本,导出App Store/AdHoc/企业版ipa,然后点击Next。如果Xcode 没有登录企业开发者账号,选择导出企业版ipa的时候会提示添加企业开发者账号到xcode。

选择证书

这里就是上面说的在工程选择的证书、profile可能并不是签名用的,关键在这里,这里会显示已经添加到Xcode的开发者账号对应的证书列表,可以选择签名用的证书。如果跟工程设置的证书一致,并且Profile匹配,则会根据工程配置的证书、Profile来签名导出。如果跟工程配置的证书不一致,则会根据选择的证书自动查找匹配的Profile来签名导出ipa。

这里会显示导出的ipa用的是哪一个证书、Profile签名的,Profile旁边那个箭头并不是选择Profile,然后在Finder中显示当前Profile。 所以导出的最后一步,尽量确认一下签名的证书、Profile是不是自己指定的。

内测分发ipa文件

内测分发ipa文件给测试人员主要有3种方法:

使用iTunes将iPa同步到手机中; 使用itms-services协议进行下载分发; 使用第三方工具进行下载分发。

请注意,无论使用何种形式分发,内测的人数限制,以及App的UDID限制始终是存在的。如果想新增加测试人员,开发者仍然需要将UDID写入Provision Profile,重新生成ipa文件进行分发。

使用iTunes进行内测分发

使用iTunes进行分发比较麻烦,需要测试用户使用数据线连接装有iTunes的电脑上,先将ipa文件添加到iTunes公司电脑限制只能浏览指定网站,再将iTunes的App同步到手机上。由于国内用户对iTunes熟悉程度不高,故不推荐大家使用这种方式进行内测分发。

使用itms-services协议进行下载分发

相比iTunes的分发方式,使用itms-service 分发的最大好处是测试用户无需使用数据线,只需打开Safari中访问包含itms-service连接的页面,单击连接后即可下载IPA文件。

itms-services的原理是itms-services指向一个plist文件,这个plist文件包含了ipa文件下载的地址,iOS设备的Safari会自动将plist中指定的ipa文件下载安装到本地。

itms-services的麻烦之处就是开发者需要自己搭建一个服务器,之后苹果在iOS 7.1 以后安装ipa公司电脑限制只能浏览指定网站,写入ipa地址的plist文件的存放地址必须是一个https的地址。

itms的结构参考如下:

安装IOS BetaV1.0 

plist的结构参考如下:

  items            assets                        kind          software-package          url                                    kind          display-image          needs-shine          0          url                                    kind          full-size-image          needs-shine                    url                              metadata              bundle-identifier        im.fir        bundle-version                kind        software        title                    

我们可以看到,虽然说用户比较方便,但对开发者而言需要写很多东西,还得搭建服务器,上OpenSSL等,比较麻烦。

使用第三方工具进行内测分发

为了避免开发者使用itms-services而带来的额外工作量,可以使用第三方工具,将ipa快速地进行内测分发。

本文整理自:【技术公开课】iOS App研发的最后冲刺:内测与部署(点击链接,观看视频),演讲PPT>>下载地址。

作者简介:

纪承,80后开发者,从业6年,现任fir.im工程师,爱折腾,爱编程。毕业于重庆邮电大学,曾负责重庆移动多个项目开发维护。

预告:2015中国移动开发者大会(MDCC 2015)将于10月15-16日在北京新云南皇冠假日酒店召开。大会特设五大技术专场:平台与技术iOS、平台与技术Android、产品与设计、游戏开发、企业移动化。此外,大会更是首次举办国内极具权威影响力的IoT技术峰会,特设硬件开发技术与虚拟现实两大专场。大会将聚集国内最具实力的产品技术团队,与开发者一道进行最前沿的探讨与交流。

第一时间掌握最新移动开发相关信息和技术,请关注mobilehub公众微信号(ID: mobilehub)。

本文到此结束,希望对大家有所帮助!

关于作者:

生活百科常识网