xcodebuild和xcrun实现自动打包iOS应用程序

随着苹果手持设备用户的不断增加,ios应用也增长迅速,同时随着iphone被越狱越来越多的app
的渠道也不断增多,为各个渠道打包成了一件费时费力的工作,本文提供一种比较智能的打包方式来减少其带来的各种不便。

自动化打包背景介绍


1、背景

随着ios程序发布的渠道逐渐的增多,为每个渠道打包也成为特别耗费时间和体力的一项技术活了,而这一般大多数都是由rd来完成的。这样就占用了
rd很多的开发时间,何不把这些东西写成一个自动化的脚本,然后交给qa 或是 pm来完成这个打包过程了。经过一番调研发现网上这种脚本还是很少的,不过xcode
提供了shell编译工具 xcodebuild 和 ipa打包工具xcrun
,这就有理由让我们利用这两个工具写一个自动化的打包脚本来提高我们的工作效率和自动化程度。

2、ios程序包格式、渠道包格式

1)
产生多渠道的原因及多渠道带来的打包问题:随着iphone、ipad、itouch等手持设备火热销售,而它们上面的应用也随之火爆了起来,而随之而来的就是以上设备被越狱后就可以在越狱的设备上直接运行ipa程序包
而不用通过appstore去下载,这样一来国内就产生了众多的专门为越狱手机而开设的渠道提供ipa程序包的下载。随着越来越多的渠道,推广时为各个渠道打包就成了一项比较耗费时间和精力的技术活了,因此我们必须寻找一种自动化的方式
让打包变得高效简单。
2)
Ios程序包分为appstore二进制文件跟渠道包两种格式
appstore二进制文件:通过xcode工具可以生成一个.app格式的二进制文件。
渠道包:格式为.ipa格式,在没有自动化打包工具之前都是利用xcode来生成相应的渠道包,而且每次只能生成一个渠道包,每次打包之前都得手动该渠道ID,带来的问题就是耗费时间、效率低下、容易出错、增加风险。

3、传统的ios打包方式

利用xcode 打包

1) appstore 二进制程序包
打开你的项目,进入“Edit Project
Settings”,进入Configuration页面,选中Release点击下面的Duplicate,复制一个新的配置项出来,命名为
Distribution。然后进入Build页面,顶上的Configuration下拉框选中Distribution,下面的Code Signing
Identity里面的Any iPhone OS Device后面对应的值选中你的那个Distribution的证书。然后点击“Build”–>
“Build” 就可以编译程序了
编译成功后,你就可以在相应的build目录下看到一个.app的二进制文件。

2) 渠道ipa包
根据以上步骤同样配置好Distribution 证书 ,然后点击 “Build”–> “Build and
Archive” 就可以编译程序了。接着打开“Window”?”Organizer” 左边栏中选择”ARCHIVED APPLICATIONS”
然后再右侧列表中选中刚才编译的程序包 再点击右侧右边顶部的”Share”按钮 保存到磁盘即可。就会生成一个.ipa的文件
即为渠道包。
注意:以上运行设备必须选择“Deveice“

4、传统的打包带来的问题

耗费时间、耗费体力、效率低下、只能依赖RD来完成、容易出错、发布风险比较高、QA回归确认比较困难、 不智能化。

自动化打包具体实现

C/C++ Code复制内容到剪贴板

  1. xcodebuild[-project][-activetarget][-alltargets][-target]...[-parallelizeTargets][-activeconfiguration][-configuration][-sdk |][=]...[]...

  2. xcodebuild[-version[-sdk |]]

  3. xcodebuild[-showsdks]

  4. xcodebuild[-find ][-sdk |]

  5. xcodebuild[-list]

1、xcodebuild 介绍:


也可以在终端输入:xcodebuild –help 或 –h查看具体的选项
显示xcodebuildversion:xcodebuild
–version
显示当前系统安装的sdk:xcodebuild –showsdks
显示当前目录下project
Information:xcodebuild –list
需要注意的是:执行以上命令时必须把位置定位在ios项目文件的根目录下
否则会提示找不相关命令的。

2、xcrun 介绍:

此工具主要用于将app文件打包成ipa格式的程序包。(主要用于已越狱手机)。
具体用法如下:

其中:-v 对应的是app文件的绝对相对路径 –o 对应ipa文件的路径跟文件名 –sign
对应的是 发布证书中对应的公司名或是个人名 
–embed 对应的是发布证书文件
注意如果对应的Distribution 配置中已经配置好了相关证书信息的话 –sign 和
–embed可以忽略

3、具体方案

a) 从源程序一次性打出所有渠道的ipa包
跟appstore的二进制包
为了让自动化脚本执行一次把所有的渠道包都打好,所以必须有一个配置文件用来存储所有的渠道名跟渠道号,而项目文件中也应该有个对应存储当前渠道号的文件,每次程序都从这个存放渠道号的文件中读取渠道号即可,大概的思路就是利用脚本循环执行打包过程,而每次打包前都通过脚本修改项目中存放渠道号的文件为当前循环的最新渠道号,让后逐个打包。
注:具体事例见附录
b)
提供一个ipa格式的母包 从母包生成其它所有的渠道包跟 appstore

qa的一些疑问,如何确保所有的渠道包就是他们验证过的那份代码呢?
的确,以上代码每次都是重新对程序进行打包,可qa往往测试验证的只有一个包,如果个个去验证无意中之中又增加了qa的工作量哈!!而且风险也不可控。因此基于上面的问题我们想出了一下办法:qa只验证一个程序包(即母包)如果这个包通过验证
我们就通过母包去生成其它渠道的包,这样一来qa也不用确认那么多的渠道包了,风险也得到了有效的控制。
可能你会问:用一个包生成其他的包可行么??
原因是这样的:因为每个渠道只是渠道号发生变化,而其他的内容又不会发生变化,而我们的渠道号又是存储在sourceid.dat这个文件中的,所以只要改变母包中的sourceid.dat文件的内容即可,而ipa包又是同zip格式进行压缩,所以基本思路就是通过zip先对母包进行解压,然后改变sourceid.dat的内容
最后再用zip进行压缩成相应的渠道包即可。
Ipa包的目录:
注:具体事例见附录

一些问题

当有些shell命令在mac的终端中运行不通过时,请确保你的shell脚本是在mac环境下编写的而不是同xp等其他环境中copy过来的。因为mac跟xp的编码是不一样所以会有问题。

总结:

通过从母包打出其他渠道的包这种方法:得到以下好处

i.   降低了rd的工作量,一起qa的工作量。

ii.  让测试发布程序时的风险得到了控制。

iii. 提高了打包发布工作效率。(几十个包 只需短短的几分钟)。

iv. 提高了自动化。

v. 不依赖mac 以及xcode环境 直接在linux 下即可完成 从母包生成其它包

附录


利用xcode环境一次生成所有包的shell 脚本代码:

C/C++ Code复制内容到剪贴板

  1. #!/bin/sh
  2. xcodebuild clean -configuration Distribution      //clean项目
  3. distDir="/Users/xxxx/dist"

  4. releaseDir="build/Distribution-iphoneos"

  5. version="1_0_0"

  6. rm -rdf "$distDir"

  7. mkdir "$distDir"

  8. for line in $(cat data.dat)        //读取所有渠道号data.dat文件

  9. do

  10. ipafilename=`echo $line|cut -f1 -d‘:‘` //渠道名

  11. sourceid=`echo $line|cut -f2 -d‘:‘`    //渠道号

  12. echo "ipafilename=$ipaname"

  13. echo "sourceid=$sourceid"

  14. targetName="youtargename"   //项目名称(xcode左边列表中显示的项目名称)

  15. echo "sourceid=$sourceid"

  16. echo "ipafilename=$ipafilename"

  17. echo "$sourceid" > sourceid.dat

  18. echo "sourceid.dat: "

  19. cat sourceid.dat

  20. rm -rdf "$releaseDir"
  21. ipapath="${distDir}/${targetName}_${version}_from_${sourceid}.ipa"
  22. echo "***开始build app文件***"

  23. xcodebuild -target "$targetName" -configuration Distribution  -sdk iphoneos build

  24. appfile="${releaseDir}/${targetName}.app"

  25. if [ $sourceid == "appstore" ]

  26. then

  27. cd $releaseDir

  28. zip -r "${targetName}_${ipafilename}_${version}.zip" "${targetName}.app"

  29. mv "${targetName}_${ipafilename}.zip" $distDir 2> /dev/null

  30. cd ../..

  31. else

  32. echo "***开始打ipa渠道包****"

  33. /usr/bin/xcrun -sdk iphoneos PackageApplication -v "$appfile" -o "$ipapath" --sign "iPhone Distribution:xxxxxx"

  34. fi

  35. done

注:以上的data.dat文件为存放渠道号列表的文件 其格式为:3g:1001b 即 (渠道名:渠道号) sourceid.dat
为项目文件中存放渠道号的文件(内容只有一个渠道号)。当然了上面脚本只是说明了下如何利用xcodebuild 和 xcrun 进行打包
以及自动打包的一个逻辑,shell脚本好的同学可以自由发挥哈。。。

从ipa格式的母包生成其它渠道包的shell脚本实例:

复制内容到剪贴板

  1. #!/bin/sh

  2. sourceipaname="母包名.ipa"

  3. appname=”app文件名.app”  //加压后Pauload目录项.app文件名需要根据自己的项目修改

  4. distDir="/Users/lxxx/Qa"   //打包后文件存储目录

  5. version="1.0.0"

  6. rm -rdf "$distDir "

  7. mkdir "$distDir" unzip $sourceipaname     //解压母包文件

  8. for line in $(cat data.dat)   //读取渠道号文件并进行循环

  9. do

  10. ipafilename=`echo $line|cut -f1 -d‘:‘`

  11. sourceid=`echo $line|cut -f2 -d‘:‘`

  12. echo "ipafilename=$ipaname"

  13. echo "sourceid=$sourceid"

  14. targetName="ipa包名"

  15. echo "sourceid=$sourceid"

  16. echo "ipafilename=$ipafilename"

  17. cd Payload

  18. cd $appname

  19. echo "replace sourceid.dat before: "

  20. cat sourceid.dat

  21. echo "$sourceid" > sourceid.dat

  22. echo "replace sourceid.dat after: "

  23. cat sourceid.dat

  24. if [ $sourceid == "appstroe" ]

  25. then

  26. cd ..

  27. zip -r "${targetName}_${version}_from_${sourceid}.zip" $appname //appstore二进制文件
  28. mv "${targetName}_${version}_from_${sourceid}.zip" $distDir

  29. cd ..

  30. else

  31. cd ../..

  32. zip -r "${targetName}_${version}_from_${sourceid}.ipa" Payload   //打成其他渠道的包

  33. mv "${targetName}_${version}_from_${sourceid}.ipa" $distDir

  34. fi

  35. done rm -rdf Payload

注:以上data.dat也是用来存储所有渠道号的,sourceipaname就是通过qa验证的母包,appname为ipa包加压后Payload
目录下的app文件名并且以上所有文件必须与脚本文件保持在同一目录下以及在mac环境中执行。

原文:http://stblog.baidu-tech.com/?p=1295

时间: 2024-08-14 08:04:19

xcodebuild和xcrun实现自动打包iOS应用程序的相关文章

Jenkins实现自动打包Android(安卓)程序

一.主要实现功能1.通过jenkins实现对安卓程序的打包2.并上传至fir.im并显示一打包信息3.上方便开发与测试人员的下载二.服务器配置:1.jenkins可以正常运行2.需要下载以下安装包https://www.androiddevtools.cn/https://developer.android.google.cn/studio/releases/platform-toolsJDK1.8gradle 最新版本 Android sdk ndksdk platform 3.配置环境变量v

iOS项目通过xcodebuild和xcrun自动发布

最近在研究App的自动生成, 使用Python编写程序替换图标,名称等,然后生成全新的应用. 通常打包采用xcodebuild和xcrun两个命令,xcodebuild负责编译,xcrun负责将app打成ipa. 常见步骤如下: 1.清理工程 /usr/bin/xcodebuild -target targetName clean 2.编译工程 /usr/bin/xcodebuild -target targetName 3.打包 /usr/bin/xcrun -sdk iphoneos Pac

iOS 本地自动打包工具

1.为什么要自动打包工具? 每修改一个问题,测试都让你打包一个上传fir , 你要clean -> 编译打包 -> 上传fir -> 通知测试.而且打包速度好慢,太浪费时间了.如果有一个工具能自动的帮你做完上面所有的事情,岂不是快哉? 2.网上有那么多自动打包工具,我直接下载就行了为啥还要学习? 没错网上有很多打包工具,包括github上也有一些直接从github下载并打包上传的,但是他们的不一定适合你,首先下载下来要配置各种参数,不会配,还有网上大多是针对普通项目,但是我们项目是coc

iOS自动打包[转载]

敲一下enter键,完成iOS的打包工作[转载] http://ios.jobbole.com/84677/ 作为开发人员,免不了要为测试人员打包,让其测试.而打包这个行为是非常无聊的,特别是在每个新版本上线前一两天,总会出现一些莫名其妙的bug,然后这两天打包活动也是特别频繁.一天要重复好几次同样的动作,作为一个程序员,去做这样的事情,是完全无法容忍的.自动化打包,好在有你.所以今天就来谈一谈iOS应用自动化打包,但是本篇文章主要谈的是打单一的测试包,并不是在讲持续集成. xcodebuild

iOS开发进阶 - 使用shell脚本自动打包上传到fir.im上-b

用fir.im测试已经好长时间了,感觉每次打包上传都很麻烦,想着是不是可以用脚本自动打包,在网上搜了一下确实有,下面总结一下如何使用脚本自动打包上传到fir.im,以及打包过程中遇到的问题和解决办法 相关资料和下载 首先是打包脚本的下载地址,这个是我找到的比较全的一个,里面有很多不同功能的shell脚本,亲测好用,传送门:https://github.com/heyuan110/BashShell?spm=5176.100239.blogcont5028.4.kFcLtR 还有关于fir指令的一

iOS开发进阶 - 使用shell脚本自动打包上传到fir.im上

如果移动端访问不佳,可以访问我的个人博客 用fir.im测试已经好长时间了,感觉每次打包上传都很麻烦,想着是不是可以用脚本自动打包,在网上搜了一下确实有,下面总结一下如何使用脚本自动打包上传到fir.im,以及打包过程中遇到的问题和解决办法 相关资料和下载 首先是打包脚本的下载地址,这个是我找到的比较全的一个,里面有很多不同功能的shell脚本,亲测好用,传送门 还有关于fir指令的一些介绍可以去这里查看,传送门 第一步安装fir-cil fir-cli 使用 Ruby 构建, 无需编译, 只要

iOS 制作自动打包脚本 Xcode8.3.2

本文包含以下内容: 前言 1.shell脚本的编写 2.xcodebuild命令 3.完整的可用示例 参考资料 前言 做iOS开发,打包APP是比较频繁的事情,每次都手动去配置一堆东西确实是比较乏味. 另外,我目前负责维护的APP在发布时,不同的Mode设置不同的AppIcon和BundleID, 所以要是可以简单执行一个脚本就完成打包的各种配置,那就轻松了! 于是乎,我就在网上学习了一下实现自动打包的方法,但是好多都是老版本的教程. 所以我打算参考别人的教程,然后自己也研究研究,再把研究的结果

使用mac进行ios自动打包(一)

随着ios平台的发展以及发布要求的多样性,测试的需求,自动打包可一定程度上提高效率. 自动打包的方式有如下几种: 一.xcode. xctool进行自动打包 参考网页地址:http://www.tuicool.com/articles/uIZRZjy 1.确保安装了xctool 没有安装xctool,可以用brew安装,没有安装brew的,可以通过搜索安装brew,然后执行如下操作安装xctool 安装命令:sudo brew install xctool 介绍下xctool命令: xctool

iOS 手动做一个自动打包部署神器

之前使用的fastlane添加pgyer自动打包的,最近发现更新总是有问题,所以产生了自己shell做一个的想法.虽然代码比较少,但是很实用. 打包 导出ipa 上传pgyer 打包自动上传pgyer 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53