工具iOS开发

App Store上架iOS App的详细流程

2018-11-06  本文已影响182人  Jay_小咖

最近负责将公司某个项目的iOS应用上架到App Store,在上架的过程中,需要做的事情很多,但很多都不涉及到太多的技术问题,但是流程很多,而且对应用有很多要求,在上架的过程中也遇到一些问题,后也顺利解决问题,成功上架了。我觉得有必要记录一下过程及遇到的问题,希望对有需要上架的iOS开发者们有所帮助。

一、注册账号

1.1 选择类型

登录苹果开发者官网https://developer.apple.com/, 点击顶部的Support,点击membership,点击enrollment,最后点击Enrollment的Learn more about these programs链接进入https://developer.apple.com/programs/, 打开这个界面后,点击右上角的Enroll按钮,滚动到最底部,点击Start Your Enrollment开始申请:

App-Store01.png

这时需要你登录Apple ID,如果没有登录Apple ID,需要先注册(https://appleid.apple.com/account), 登录后会显示你的Apple ID的基本信息,在下方会要你选择账户类型,选择第二个,公司/企业账户:

App-Store02.png

1.2 申请邓白氏码

不要点击continue,点击Check now,检查公司是否已经有邓白氏码,如果没有,填写申请信息进行申请:

App-Store03.png

大概3~5个工作日后,邓白氏会发一封邮件到你邮箱中。然后将公司的详细资料准备好,当他们发邮件要资料时,需要快速的给到他们。申请通过后,我们会收到邓白氏码,但是要半个月后才能使用,因为苹果需要同步数据。

1.3 继续填写公司信息

等待一段时间后,重新进入enroll界面,选完类型后,直接点击继续,接着要填写公司的信息,要真实,跟营业执照上的一致。


App-Store04.png

然后继续核对一下信息,最下方如果出现当时申请邓白氏码的时候填写的地址的话,说明信息已经同步了,然后继续。
说明提交成功了,等待苹果的审核。

1.4 支付费用

很快苹果就给你留的电话,问一下基本的问题,然后就给你发了一份邮件。
点击里面的地址跳转登录之后,勾选协议,就跳转到支付界面。
提前准备一张支持visa或者万事达的信用卡,支付的时候要用到.填写信用卡信息,发票信息之类的。

二、申请开发者证书

两种主要的证书说明:


App-Store08.png

这是我们在开发者中心申请成功后下载到本地的发布证书(.cer文件),对应的还有ios_development.cer开发证书,双击后会安装到钥匙串中生成一个证书(含有公钥和私钥)。它的作用是让开发者使用的设备(也就是Mac)具有真机调试发布应用或应用签名的权限。我们在团队开发中,一般需将这个证书导出p12格式共享给其他有需要的成员(如新员工)。

App-Store09.png

这是我们配置好证书后生成,下载到本地后的.mobileprovision文件,也就是我们常说的描述文件(PP文件),双击后可安装到Xcode中,或在Xcode中登录Apple ID后,下载到Xcode对应目录。它的作用是让开发者的项目(App),具有真机调试,发布的权限。

2.1 申请钥匙串文件

在Mac的其他工具中找到钥匙串,在左上角点击的钥匙串访问->证书助理->从证书颁发机构请求证书…:

App-Store10.png

填写邮箱地址:


App-Store11.png

选择保存的目录:


App-Store12.png

在桌面上就生成了一个CSR文件:


App-Store13.png

2.2 在开发者中心申请证书

App-Store14.png

2.2.1 选择Certificates申请新证书:

App-Store15.png

2.2.2 选择需要的证书类型,开发使用选择开发证书,发布应用使用的选择发布证书:

App-Store17.png

这时我们要用到刚从钥匙串中制作的.certSigningRequest(CSR)文件:

App-Store18.png

这个CSR其实就是公钥,私钥保存到了钥匙串中。
点击继续后,完成了证书的制作:


App-Store19.png

点击Download将生成的证书下载到本地(此时生成了.cer文件),双击运行,没有反应,但是在钥匙串->证书中查看已经安装了该证书。

2.2.3 注册App ID

App-Store21.png

点击Register完成注册。

2.2.4 制作APNs推送证书

申请好App ID后,我们可以开始制作远程推送用的证书,推送证书也分为两种,一种是测试用的推送开发证书,一种是上线用的推送发布证书。

2.2.4.1 点击申请好的App ID,点击Edit:

App-Store22.png

如果没有配置推送证书的话,在Push Notifications项是显示Configurable。

App-Store24.png

2.2.4.2 拉到下面,可以看到分为开发用证书和发布证书,选择对应的类型即可,这里选择发布证书,点击create certificate:

App-Store25.png

2.2.4.3 要求上传CSR文件,即在第一步钥匙串中生成的CSR证书。

2.2.4.4 下一步,制作完成,可以看到APNs证书,点击下载到桌面。

下载后双击安装进钥匙串中。此时开发者中心对应的App ID的推送变成了Enabled,说明推送服务可用了。


App-Store26.png

2.2.4.5 推送的P12证书的制作

双击刚下载下来的aps.cer文件,这时会在钥匙串中安装了APNs的证书,右键将它导出为p12的格式,设置密码,发给服务端人员推送使用,当服务端人员使用这个p12证书时需要密码。


App-Store29.png

选择p12格式,输入密码,服务端要用时,同时将p12证书及密码发给他们。同理,开发调试用的开发证书也同样处理。


App-Store30.png

2.2.5 添加注册设备

一般当使用Ad Hoc的发布方式才需要该操作步骤。

2.2.5.1 在Devices出,添加要注册的设备:

App-Store31.png

2.2.5.2 填写设备信息:

App-Store32.png

如何获取设备的UDID:
1)将设备连接Mac,使用iTunes查看:


App-Store33.png

2)在Xcode的window—>Devices中查看:

App-Store34.png

3)使用蒲公英的方式获取:
https://www.pgyer.com/doc/view/udid

2.2.6 创建描述文件

Provision Profiles中配置描述文件:

App-Store35.png

选择配置的类型:


App-Store36.png

PS:更新,上图的Ad Hoc表述错误。Ad Hoc的发布方式主要是用于在指定的设备上测试使用(类似灰度测试),这种发布的方式需要注册设备UDID,只有在对应的设备ID的设备才能够进行安装测试,最多可添加100台设备。
接下来选择App ID:

App-Store37.png

继续选择证书:


App-Store38.png

如果配置开发证书,则这里只有开发证书可以选择,配置发布证书,则只有发布证书可以供你选择,所以也不用担心会选错。
如果配置开发证书,还需要配置这个项目哪些设备可以作为真机测试:


App-Store39.png

点击继续完成创建:


App-Store40.png

可点击下载,将.mobileprovision文件下载到本地,双击安装进Xcode对应的目录。
可以看到,.mobileprovision文件包含了证书App ID设备

三、在iTunes Connect创建App

3.1 新建一个iOS App

App-Store41.png

点击新建App:


App-Store41.png

3.2 填写基本信息

App-Store44.png

需要上传5张图片,可以只上传5.5寸的介绍图片,如果应用也支持iPad的,同时需要上传一张12.9英寸的iPad截图。


App-Store46.png

填写关键词、描述文字等:


App-Store47.png

填写App综合信息:


App-Store45.png

需要注意的是,如果App中有需要登录注册功能的,记得提供一个测试账号。


App-Store48.png

四、配置Xcode,打包

4.1 设置Scheme

App-Store49.png

将Archive的Build Configuration设置为Release:


App-Store50.png

Run中Build Configuration也设置为Release:

App-Store51.png

不要勾选启动僵尸对象:


App-Store52.png

4.2 设置代码签名

App-Store54.png

注意要同时将TARGETS及PROJECT的代码签名都设置成Distribution

4.3 设置应用名称及版本号

App-Store55.png

4.4 开启消息推送

开启Push Notification:


App-Store56.png

Entitlements文件中配置APS Environment

App-Store57.png

钥匙串中要安装有APNs推送证书。

4.5 选择发布证书

由于自动签名管理成开发证书,这里手动进行管理,选择对应的发布描述文件。


App-Store58.png

4.6 勾选全屏显示(iPad)

勾选 Requires full screen:

App-Store59.png

不勾选的话,上传时需要你实现iPad的多任务分屏

4.7 添加各种对应尺寸的图标

App-Store60.png

4.8 打包并导出

选择对应的Target,选择真机模式,不然Archive会变灰,不能点击:


App-Store61.png

然后会提示访问钥匙串中的密钥:


App-Store62.png

成功后,弹出如下界面:


App-Store63.png

选择Export导出ipa,选择第一个,发布到App Store:


App-Store65.png

点击Next,会要选择发布证书:


App-Store66.png

检测通过之后,选择导出,会生成一个有日期的文件夹,里面包含了要发布的ipa包,ipa包的制作完成。

五、使用Application Loader上传App

打开Xcode的Application Loader:

App-Store67.png

输入开发者账号和密码后,选择导入刚才导出的ipa包,需要一定的时间(约10~20分钟)来鉴定App。最后会出现如下的信息:


App-Store68.png

提示成功,说明我们已经将包顺利的上传到了App Store。

六、在iTunes Connect选择构建版本,最后提交审核

App-Store69.png

然后可以先点击存储,确保所有修改的地方都有保存。最后确定所有信息都填写无误后,提交以供审核。这是我们已经完成了上架的工作,接下来就是等待苹果的审核,一般3~7个工作日会收到苹果的审核结果,如果在iTunes Connect上显示可供销售,说明已通过审核,如果显示被拒绝,则需要根据苹果的拒绝理由进行修改再重新提交。

七、发布过程中遇到的一些问题及解决

7.1 上传时遇到的错误

在使用Application Loader上传App时遇到了一下问题,如下:

App-Store70.png

经分析:如果主要是缺少一些支持iPad的图标、没有实现iPad Multitasking(iPad的多任务分屏)及不允许包含libReveal.dylib动态库。
解决的方式:

7.2 在提交审核时报的错误

分类中明明选了生活,但是被强制变成了杂志类应用,且一定要提供隐私政策网址(20181003后强制要提供,否则拒绝上架)。
解决方式:打包将info.plist文件中的Newsstand Icon的键删除,否则会被自动判定为该应用是报刊杂志类的应用,即使选择了分类也无效:

App-Store72.png

7.3 是否包含广告标识

检测ipa包中是否包含了广告标识:
cd 到你工程目录,执行下面的命令:

$ grep -r advertisingIdentifier .

检测到了项目中的某个库中包含了广告标识,解决方式有两种:
1)在是否使用广告标识中选择“是”,并提供IDFA的使用信息;
2)将库从项目中移除,再进行打包上传,在广告标识中选择“否”。

至此,所有的上架相关的工作基本做完了。

上一篇下一篇

猜你喜欢

热点阅读