引入简书:http://www.jianshu.com/p/b600c16308f4
# iOS开发笔记 - 上线流程
>
![](https://box.kancloud.cn/42326eb5da40d1a9d3e3aa3609faaaad_1240x768.png)
> 在开始讲述上线流程之前,我们假设你已经拥有了Apple ID,但是还没有成为付费的开发者,我们就从申请成为付费开发者开始。
>
![](https://box.kancloud.cn/31a4f1d87d17a14141579369c197ea8e_1240x920.png)
图1. 用浏览器打开苹果开发者网站
* * * * *
![](https://box.kancloud.cn/fde0437963798f66f30309bc6f25c3ad_1240x920.png)
图2. 使用Apple ID登录开发者网站
* * * * *
> 注意,如果你是第一次使用你的Apple ID登入苹果开发者网站,你会看到如下所示的页面,这个时候你需要同意“苹果开发者协议”,并提交你的请求,这个时候你的Apple ID就已经成为一个开发者ID了。
![](https://box.kancloud.cn/807dde2dc10bc9eb3e1e30408e9ac1a8_1240x920.png)
图3. 苹果开发者协议页面
* * * * *
![](https://box.kancloud.cn/47bbd203f6c9c38a2c67a7ed69d8e6bb_1240x920.png)
图4. 同意苹果开发者协议并提交申请
* * * * *
![](https://box.kancloud.cn/ae48d607a61168882eacecc4f08b87a1_1240x920.png)
图5. 加入苹果开发计划
* * * * *
接下来的页面中你会发现一个注册的按钮,点击它就可以申请成为付费的开发者了。
![](https://box.kancloud.cn/f9ad603f8f6d1cfcbf60dd447dd47153_1240x920.png)
图6. 点击注册按钮
* * * * *
![](https://box.kancloud.cn/19647fe15e94b6d402b562d72c54e73c_1240x920.png)
图7. 点击开始注册
* * * * *
在接下来的页面中选择开发者类型后就可以继续了。
![](https://box.kancloud.cn/da5e5d344c01394f5a33435f76427dfa_1240x913.png)
图8. 选择开发者类型并继续
* * * * *
> 注意:个人开发者需要每年支付99美元的费用,而企业开发者需要每年支付299美元的费用。
> 接下来需要填写一大堆的注册信息,而且需要本土语言和英语两种版本,然后还得再次同意一个你不太愿意阅读但是必须得同意的协议。点击“Continue”后会进入下一个页面,如果刚才的信息无误,就再次点击“Continue”按钮进入准备支付的页面。
![](https://box.kancloud.cn/c075c2151ff0f4aa205407503c3464d4_1240x920.png)
图9. 填写注册信息
* * * * *
![](https://box.kancloud.cn/ceb67475c442f2125e9c9857c023bac7_1240x920.png)
图10. 同意协议并且继续
* * * * *
![](https://box.kancloud.cn/ad5f16f0e03cec085a53d25c678abe64_1240x920.png)
图11. 点击支付按钮
* * * * *
> 接下来还得登录一次,然后终于可以把钱付给Apple了,真是不容易啊,不过你还得有Visa信用卡或者是MasterCard。
>
![](https://box.kancloud.cn/28b1cee83fdd655611342f434f26bccd_1240x920.png)
图12. 再次登录
* * * * *
![](https://box.kancloud.cn/8596ac519ae561d1089613a73ae12ca1_1240x920.png)
图13. 填写付费信息的页面
* * * * *
> 剩下的步骤你就按照网页上的提示操作就可以了,国内的很多银行在进行境外支付时可能会给你来电话确认支付授权,所以上面填写的信用卡信息以及账单联系人信息必须匹配,否则基本上会支付失败,即便你通过网上银行开通了境外支付。在上面的页面中还需要填写发票信息,如果需要机打发票的话这里的信息就不要填错了哈。
> 支付成功后,苹果会在48小时内对订单进行处理,然后你可能会收到邮件要求到指定的页面上传身份证照片。如果遇到任何问题,你可以拨打苹果开发的售后服务电话,号码是4006701855。成为开发者后再次登录,就会看到如下所示的页面。
![](https://box.kancloud.cn/d7fea5c939d9602934cafc71821b7524_1240x920.png)
图14. 成为付费开发者后重新登录
* * * * *
![](https://box.kancloud.cn/e73953e83f813798c40ce6337029a0ef_1240x920.png)
图15. 付费开发者登录后的界面
* * * * *
> 上图中点击红框的链接可以进入创建证书、应用ID和Profiles文件的页面;点击篮框的链接可以进入管理自己的App的页面。
![](https://box.kancloud.cn/03c55000f3e90262ee0afc87847e73fd_1240x920.png)
图16. 创建证书的页面
* * * * *
> 点击上面页面中左侧的证书,并在右侧点击“+”就可以创建证书。
>
![](https://box.kancloud.cn/c316bde6c8451231b435ca6138c161f3_1240x920.png)
图17. 选择证书类型的页面
> 在上面的页面中选中红框中的选项可以创建开发证书,主要用于真机测试;选中蓝框中的选项可以创建产品证书,用于应用上线到App Store或小范围发布。我们下面要演示完整的项目上线流程,因此在这里选择蓝框中的选项“App Store and Ad Hoc”并点击“Continue”按钮继续。
> 接下来的页面会提示你创建证书需要一个证书签名请求文件,因此我们需要在自己的Mac系统上使用“钥匙串访问”应用创建一个证书签名请求文件
* * * * *
![](https://box.kancloud.cn/22e3e3ea23723aa234eff70c243ec297_1240x920.png)
图18. 提示创建证书签名请求的页面
* * * * *
![](https://box.kancloud.cn/ed97bee7117cb27cd10c51cc43b43825_1240x759.png)
图19. 通过Launchpad打开“钥匙串访问”应用
* * * * *
![](https://box.kancloud.cn/6a7b9e7b8acd0d92587fa561d816f7d8_1096x564.png)
图20. 通过“证书助理”创建证书签名请求
> 注意:在上面的界面中要选中“从证书颁发机构请求证书…”菜单项才能打开如下所示的界面。
>
![](https://box.kancloud.cn/abdbd7849465c12e8924d614c6e25ef3_1232x872.png)
图21. 将证书签名请求文件保存到桌面
* * * * *
![](https://box.kancloud.cn/299ae3d98df3f36e5445a5aeec8190a0_1240x920.png)
图22. 选择证书签名请求文件并继续
* * * * *
> 接下来可以将生成的证书下载到下来并双击添加到“钥匙串”中。
>
![](https://box.kancloud.cn/daef4caa186b3bf2c43cd87b716c9dc0_1240x920.png)
图23. 下载创建好的证书
* * * * *
![](https://box.kancloud.cn/9358f4d676e9e853a06aab282ff24506_1068x600.png)
图24. 将证书添加到钥匙串中
* * * * *
![](https://box.kancloud.cn/d4f6a6efaa7577aea08b3dcf6735b6b6_1240x833.png)
图25. 在“钥匙串”中查看证书
* * * * *
> 接下来选中页面左侧的“Identifiers”并点击右侧的“+”来注册要上线的应用程序ID
>
![](https://box.kancloud.cn/012eeaaca7c865e3b4cab90b95e98a4a_1240x920.png)
图26. 注册应用的ID
* * * * *
![](https://box.kancloud.cn/3d7ba826999d5faa009f81cc6f46364e_1240x920.png)
图27. 填写应用ID的名称和Bundle ID
* * * * *
~~~
注意:上面的Bundle ID应该跟Xcode中项目的Bundle ID保持完全一致,此处最好确认一下Xcode中的Bundle ID,如下所示。
~~~
![](https://box.kancloud.cn/6ed0a0b1ccee7aa74b29610acc8a79a6_1240x864.png)
图28. 在Xcode中查看或修改项目的Bundle Identifier
* * * * *
![](https://box.kancloud.cn/e8038c4bb93b79cd2f10c3c648a0c834_1240x920.png)
图29. 可以对项目使用的服务进行设置并继续
* * * * *
![](https://box.kancloud.cn/0afba094a09614c6694f27b1248ccaab_1240x920.png)
图30. 完成应用ID注册
* * * * *
> 上面一步完成后还要点击“Done”按钮,然后就可以在“App IDs”中看到所有注册过的应用程序的Bundle ID。接下来就可以用证书和注册的应用程序ID来生成“Provisioning Profiles”,你可以把这个文件理解为一个配置文件(后文中将“Provisioning Profile”统称为“配置文件”),有了这个文件才能对你的项目代码用证书进行签名并完成上线的操作。
![](https://box.kancloud.cn/a32d52b7930dc721b37a9f0e94247310_1240x851.png)
* * * * *
图31. 查看Provisioning Profiles
![](https://box.kancloud.cn/a32d52b7930dc721b37a9f0e94247310_1240x851.png)
* * * * *
点击页面右上方的“+”开始创建“配置文件”。
![](https://box.kancloud.cn/1be1e4979d252b06a67f6b0d4e6339ac_1240x851.png)
图32. 创建新的“配置文件”
* * * * *
![](https://box.kancloud.cn/9241ebb1dd901f3ae01c478ba7c9fbb1_1240x851.png)
图33. 选择“配置文件”的类型
* * * * *
![](https://box.kancloud.cn/ff9419eebba27ecc1b1791a9ba52613c_1240x851.png)
图34. 选择应用程序ID
* * * * *
![](https://box.kancloud.cn/073cee21444af038248a973edc757649_1240x851.png)
图35. 选择使用的证书
* * * * *
![](https://box.kancloud.cn/41033dae70122e9aac228e95e154cc46_1240x851.png)
图36. 给“配置文件”命名
* * * * *
![](https://box.kancloud.cn/41033dae70122e9aac228e95e154cc46_1240x851.png)
图37. 下载“配置文件”并点击“完成”按钮
* * * * *
> 下载好的配置文件可以双击添加到Xcode中,待会就可以使用这个配置文件来完成项目的上线不过现在我们暂时放下这件事情,回到开发者中心,进入“iTunes Connect”。
>
![](https://box.kancloud.cn/f01683d4374e56ed4a9f223c559652df_1240x851.png)
图38. 回到开发者中心
* * * * *
![](https://box.kancloud.cn/871c3cb273118b4d3f12c69748068d8d_1240x851.png)
图39. 进入iTunes Connect
* * * * *
![](https://box.kancloud.cn/ab55aac6eec18b96d01f3ad012518c10_1240x851.png)
图40. 管理App
* * * * *
![](https://box.kancloud.cn/9d84751c310e447a1aa378f55fea2688_1240x851.png)
图41. 新建App
* * * * *
![](https://box.kancloud.cn/1d2973ded7a5fc99446c1355bdd0285e_1240x851.png)
图42. 填写App相关信息
* * * * *
~~~
说明:上图中“名称”是你的应用在App Store中显示的名字;“套装ID”是Xcode中项目的Bundle Identifier;“SKU”可以填写当天日期外加一个编号即可,这是你为你的应用指定的一个标识符。
~~~
接下来的页面中可以指定应用的类别。
![](https://box.kancloud.cn/0475d4383dc510ee293d58987d9d9af3_1240x851.png)
图43. 指定应用程序类别并存储
* * * * *
![](https://box.kancloud.cn/8783ddbf9dd2917aa888fef8338f6cc9_1240x851.png)
图44. 点击“1.0准备提交”填写App相关信息
* * * * *
![](https://box.kancloud.cn/8cb7912111a4ea944be02736a0766d43_1240x851.png)
图45. 添加App预览和屏幕快照
* * * * *
![](https://box.kancloud.cn/f3d05f01ff326bd3a77eda2aefea379c_1240x851.png)
图46. 编写应用描述和关键词
* * * * *
![](https://box.kancloud.cn/9efedfda9536848d0406478adcbed41e_1240x846.png)
图47. 设置应用图标并编辑应用分级
* * * * *
~~~
注意:应用图标必须提供1024*1024的图片且图片不能设置alpha通道(透明度);应用分级是为了确定应用使用群体的年龄段,如下图所示。
~~~
![](https://box.kancloud.cn/52190a957d1ea4619ee9b01342521172_1240x851.png)
图48. 编辑应用分级
![](https://box.kancloud.cn/78c7bd68822b305ba9b438ed19ad4671_1240x851.png)
图49. 设置完图标和应用分级后的效果
* * * * *
![](https://box.kancloud.cn/ba39607ab2d302fe8cdaaab94c6d9494_1240x851.png)
图50. 提供联系人信息和演示账号
* * * * *
~~~
说明:如果你的应用中有需要登录后才能使用的功能那么就必须提供一个演示账号以供审核应用时使用。
~~~
![](https://box.kancloud.cn/e71e34626e5f55018758a4d79aae5647_1240x851.png)![](https://box.kancloud.cn/e71e34626e5f55018758a4d79aae5647_1240x851.png)
图51. 选择发布方式并保存应用信息
> 接下来就要回到Xcode提交应用程序的代码以供审核,如下图所示我们可以在项目的“Build Settings”中设置代码签名和“配置文件”,可以在上面的工具栏中选中“Generic iOS Device”,然后用“Product”菜单中的“Clean”菜单项对项目做一次清理,再用“Archive”菜单项来对项目进行打包操作。需要提醒的是,如果代码签名出现问题,可以通过如下图所示的“Fix issue”按钮进行联网修复。
![](https://box.kancloud.cn/faa8314d998fadc5e6652f4e175e868a_1240x699.png)
图52. Xcode中设置代码签名和“配置文件”
* * * * *
![](https://box.kancloud.cn/68c03687eca847bff423fc1461a0b66a_1240x699.png)
图53. 联网修复代码签名问题
* * * * *
![](https://box.kancloud.cn/69d80da42b3bdc408bdaf1d125c2159d_1240x681.png)
图54. 通过“Product”菜单的“Archive”菜单项启动打包上传工具
* * * * *
> 点击上图红框中的按钮可以上传项目到App Store;点击蓝框中的按钮可以对项目进行验证;点击绿框中的按钮可以将项目导出成ipa文件。
>
![](https://box.kancloud.cn/5af12632cbe648233e0811c04aa9ae79_1160x700.png)
图55. 验证项目界面
* * * * *
![](https://box.kancloud.cn/e282ec731fcc8f207fb4bb4a9ef851b5_1160x700.png)
图56. 导出项目的界面
* * * * *
![](https://box.kancloud.cn/48490b1ab2f13deb286c193bdacad242_1160x700.png)
图57. 选择导出的目标设备
* * * * *
导出成功后会看到如下图所示的文件。
![](https://box.kancloud.cn/476ae886e46ec2641acc1fb851f2a027_200x200.png)
图58. 导出后生成的ipa文件
* * * * *
> 可以使用类似于蒲公英这样的内测分发工具将ipa文件上传生成一个二维码,这样可以让所有的测试机通过扫描二维码安装该应用来进行内测,如下图所示。
>
![](https://box.kancloud.cn/914310975d2da9d6a6d4bbe0a4db2527_1240x809.png)
图59. 蒲公英界面
* * * * *
![](https://box.kancloud.cn/e4673d7f9ba73e50c271c21071c71088_1200x1244.png)
图60. 上传ipa文件并生成二维码
* * * * *
![](https://box.kancloud.cn/f96c3d73ecb4cbc9b84bec1e5d0b455c_1240x722.png)
图61. 上传成功后打开应用对应的页面
* * * * *
> 经过严格的内测后,是时候将应用上传到App Store啦。
>
![](https://box.kancloud.cn/ca78165f7d921224debf1dab5443f6b6_1160x700.png)
图62. 点击“Upload”上传到App Store
* * * * *
![](https://box.kancloud.cn/5dd8bc12cae7e192bd263faa82e8d212_1160x700.png)
图63. 正在上传应用到App Store
* * * * *
~~~
这个过程可能会比较漫长,你可以放轻松一些,冲一杯咖啡奖励一下自己然后等待上传的结果。
感觉怎么样,是不是觉得上线一个项目还真不容易。这就对了,因为成年人的生活中本来就没有容易二字。
~~~
- 关于我们
- ApiCloud
- 支付模块
- 微信支付--wxPay(客户端)
- 微信支付--wxPay(服务端)
- 支付宝支付--aliPay(客户端配置)
- 支付宝支付--aliPay(服务端配置)
- DoT模板
- 缓存模块
- 监听模块
- 百度定位模块
- 设置状态栏字体颜色
- 选择城市插件
- 跨页面执行方法
- 安卓-点击返回事件
- 上传图片模块
- 点击弹出放大图片层
- 魅族手机apiready问题
- 分享
- 跨win或frm执行脚本
- 关于ios数字自动识别成手机号
- 百度地图bMap
- 语音识别模块
- tabBarMenu底部导航
- 第三方登录
- QQ网站和appQQ账号的统一问题解决
- 微信登录
- QQ登录
- 微博登录
- 上拉加载、下拉刷新模块
- 图片缓存
- 文件和图片缓存机制分享
- PHP
- 支付宝及时到账
- no input file specified报错解决
- thinkphp 整合kindeditor
- 整合tpshop微信模块到thinkcmf中
- thinkphp3.1.3整合支付宝
- 网站接入QQ OAuth2.0登录教程
- ThinkPHP整合百度编辑器Ueditor
- PHP加快执行效率的写法规范
- ThinkPHP操作大全
- PHP操作大全
- Thinkphp中SQL操作返回值
- php5.3 foreach 使用&(与运算符)引用赋值要注意的问题
- mysql给字段追加值
- 阿里大鱼短信平台接入
- Navicat 导出 Mysql 数据字典
- php 面向对象全面教程
- PHP5下调用SOAP
- PHP处理时间格式添加空格
- 伪装URL请求(.htaccess)
- url请求参数加解密
- JS插件
- artDialog弹窗-页面传值
- jQuery点击遮罩弹出层固定居中
- jeBox原生弹窗
- bxslider轮播
- js生成指定位数随机数
- 发送短信倒计时
- js调试
- jQuery.validator 表单验证规则
- Swiper 轮播
- 获得焦点时-图片抖动
- uploadify无刷新上传图片
- 导航下拉隐藏上拉显示
- 获得焦点时-加黑色蒙版
- jquery.qrcode.js生成二维条形码(支持中文)
- jquery.qrcode.js生成二维条形码(官方不支持中文)
- nth-child 选择器
- 无刷新点击实现加载更多数据
- 刷新页面方法
- 判断滚动条向上向下
- 跨浏览器复制jQuery-zclip
- js校验表单后提交表单的三种方法
- 用JS判断下拉框是否选中
- div中滚动
- 提交时弹出模态框
- 当图片不显示时替换方法
- 前端
- CSS3
- HTML5
- css技巧
- 移动端rem
- Flex布局
- 电商详情滚动条监听
- VueCircleMenu圆环按钮
- iframe自适应页面高度
- 百度Echart
- input:radio改变选中颜色
- Jquery
- 响应式布局基本实现Media Query
- 循环输出只输出新内容
- 小程序
- wx.request坑
- 概要
- git操作
- 本地记住密码
- 操作
- 生成ssh公钥 记住密码
- git避坑
- ES6学习手札
- 调试小插件
- 谷歌插件Postman
- PHP调试助手
- WordPress
- 缓存服务器Redis
- 在线代码运行 Docker
- 在ubuntu下怎样安装https
- BrowserSync 浏览器同步测试工具
- getmarkman高效的设计稿标注、测量工具
- PHPstrom软件
- 服务器
- linux 安装搭建服务器配置及nginx配置
- tpshop的nginx 服务器配置方法
- (服务器访问文件404解决办法)IIS 之 添加MIME扩展类型及常用的MIME类型列表
- mysql部分
- mysql缓存
- MySql监控工具--mytop
- MySql主从搭建
- mysql优化
- Mysql 复制 (主从复制)
- iOS开发笔记 - 上线流程
- VUE避坑指南
- 从零开始学Vue
- Vue-cli
- Webpack
- VUE小记
- npm打包空白
- 打包背景图片/项目图片不显示
- VUE避坑指南/elementUI upload 自定义http-request上传
- 关于watch监听路由重复加载方法
- 解决加载内容的时候闪动问题
- vuecli没有network访问地址
- python学习
- python初始
- pytho内置函数大全
- win10 播放器播放TS文件问题
- 设计网站
- VUE避坑指南/VUE-CLI部署空白
- swiper使用问题
- uni-app学习手册
- 目录结构
- layUI
- nodesass版本sassloader版本问题