做iOS开发时间久了,打包APP一定是比较频繁的事情,每次都需要各种点点点。。。要是能简单执行一个脚本就生成ipa,那就轻松了!
于是开始在谷歌学习如何制作自动化打包脚本,但是好多都是老版本。所以我打算参考别人的教程,再自己研究研究,最后把研究成果进行一个总结,方便日后查阅。
参考文章:
http://www.jianshu.com/p/97c97c2ec1ca
http://www.jianshu.com/p/3f43370437d2
http://blog.csdn.net/potato512/article/details/52172107
http://blog.csdn.net/itiapp_home/article/details/70241011
Begin to do
小牛试刀
其实当Xcode点击build或者运行comand+R之后,Xcode执行的命令是xcodebuild这条命令。
打开终端,cd到你的工程位置,然后试一下xcodebuild、xcrun命令,看看自己电脑是否安装了xcodebuild及xcrun。
# xcodebuild
kuangzihandeMacBook-Pro:YuanKezi kuangzihan$ xcodebuild -version
Xcode 9.1
Build version 9B55
# xcrun
kuangzihandeMacBook-Pro:YuanKezi kuangzihan$ xcrun --version
xcrun version 35.
xcodebuild命令是苹果官方推出的打包命令,可以在终端输入xcodebuild -help
查看,也可以看官方文档。
背景知识
在8.3之前推荐使用xcodebuild + xcrun
的PackageApplication
的方式打包,笔者在学习过程中也使用过,但是执行命令行时报错xcrun: error: unable to find utility "PackageApplication", not a developer tool or in PATH
,提示很明显在路径中找不到PackageApplication
文件,虽然网上也有提供下载PackageApplication
方式的解决方法,但笔者在Xocde9下尝试无效。
于是笔者使用了官方推荐的arhive+exportArchive
的方式来打包。本文也主要讲解如何通过arhive+exportArchive
方式打包。
命令行
生成Archive包
首先需要在xcode项目配置好证书及描述文件,然后打开终端cd到项目目录,执行编辑并清理命令。
xcodebuild archive
-workspace 项目名称.xcworkspace (非cocoapods项目使用 -project 项目名称.xcodeproj)
-scheme 项目名称
-configuration 构建版本(Debug or Release)
-archivePath archive包存储路径
clean archive 清理
- -workspace or -project
此处有区别,如果非cocoapods项目使用-project 项目名称.xcodeproj
,cocoapods项目使用-workspace 项目名称.xcworkspace
; - -scheme 可以通过
xcodebuild -list
获取; - -configuration 一些参数,也可以通过
xcodebuild -list
获取,一般使用Debug
orRelease
; - -archivePath 生成archivePath的路径,一般放项目目录下并且自定义一个文件夹名称,例如
archive/test.xcarchive
; - clean archive 编译之前清理;
生成ipa文件
上文已经提到PackageApplication
已经不推荐,本文通过arhive+exportArchive
来实现打包。
xcodebuild -exportArchive -archivePath archive文件的地址.xcarchive
-exportPath 导出ipa文件路径
-exportOptionsPlist exportOptionsPlist文件路径
-allowProvisioningUpdates 允许配置更新
- -archivePath 此路径为
生成Archive包
步骤中生成的archive路径; - -exportPath 设置导出ipa文件路径;
- -exportOptionsPlist
此处需要详细说明下,笔者在调研过程中也卡在此处,此plist并非项目中info.plist
文件路径,是需要新建一个plist
文件,格式是如下:
** ExportOptions.plist文件参数说明 **
compileBitcode:不上架App Store,Xcode是否启用Bitcode重新编译,默认为YES。
method:归档类型,包括app-store、ad-hoc、package、enterprise、development以及developer-id。
uploadBitcode:上线App Store是否开启Bitcode,默认为YES。
uploadSymbols:上线App Store,是否开启符号序列化,这是与查crash相关的,默认为YES。
特别说明下,在Xcode9之前是不需要ExportOptions.plist
,在Xcode9之后必须加入 ExportOptions.plist
;
最后此处指向创建plist文件的路径即可;
- allowProvisioningUpdates 允许配置更新;
生成Shell脚本介绍
上面所述均是通过命令行的方式实现打包,但执行起来还需要输入命令行,还是不太方便,下面介绍通过生成一个Shell脚本来来实现一键打包。(详细的Sell命令,有兴趣的同学可以在Shell教程中详细学习)
首先打开终端输入如下命令:
touch test
打开文件,输入如下:
#!/bin/sh
echo "Hello Shell"
然后执行:
chmod +x test
执行成功后查看之前test文本文件,变成了Unix可执行文件(即生成了一个简单脚本),双击脚本即可查看打印的Hello Shell
,如下:
kuangzihandeMacBook-Pro:~ kuangzihan$ /Users/kuangzihan/test ; exit;
Hello Shell
logout
Saving session...
...copying shared history...
...saving history...truncating history files...
...completed.
[进程已完成]
一键打包Shell脚本
以下是我自动打包的主要代码:
#! /bin/bash
# created by Ficow Shen
#工程绝对路径
project_path=$(pwd)/TestProjects
#工程名称
project_name=TestProjects
#打包模式 Debug/Release
development_mode=Debug
#scheme名
scheme_name=TestProjects
#archive文件夹名称
archive_path=archive
#plist文件所在路径
exportOptionsPlistPath=$(pwd)/iOS/IPA.plist
#导出.ipa文件所在路径
exportFilePath=$(pwd)/Desktop/${scheme_name}_IPA
echo '*** 正在 编译工程 For '${development_mode}
xcodebuild \
archive \
-workspace ${project_path}/${project_name}.xcworkspace \
-scheme ${scheme_name} \
-configuration ${development_mode} \
-archivePath ${project_path}/${archive_path}/${project_name}.xcarchive \
clean archive \
-quiet || exit
echo '*** 编译完成 ***'
echo '*** 正在 打包 ***'
xcodebuild \
-exportArchive \
-archivePath ${project_path}/${archive_path}/${project_name}.xcarchive \
-exportPath ${exportFilePath} \
-exportOptionsPlist ${exportOptionsPlistPath} \
-allowProvisioningUpdates \
-quiet || exit
if [ -e $exportFilePath/$scheme_name.ipa ]; then
echo "*** .ipa文件已导出 ***"
open $exportFilePath
else
echo "*** 创建.ipa文件失败 ***"
fi
echo '*** 打包完成 ***'
修改如下几点即可使用此脚本实现一键打包:
- project_path
$(pwd)
为电脑的用户目录,此处填写项目根目录即可; - project_name 此处修改为项目名称;
- scheme_name 此处同样可以修改为项目名称;
- exportOptionsPlist 此处需要填写上文提到的
exportOptionsPlist.plist
文件所在目录; - exportFilePath 导出ipa文件路径,默认设置桌面;