XCode9制作一键打包脚本

做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 + xcrunPackageApplication的方式打包,笔者在学习过程中也使用过,但是执行命令行时报错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获取,一般使用DebugorRelease
  • -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文件,格式是如下:
XCode9制作一键打包脚本_第1张图片
ExportOptions.png
** 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
XCode9制作一键打包脚本_第2张图片
在user目录可看到生成的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 '*** 打包完成 ***'

修改如下几点即可使用此脚本实现一键打包:

  1. project_path $(pwd)为电脑的用户目录,此处填写项目根目录即可;
  2. project_name 此处修改为项目名称;
  3. scheme_name 此处同样可以修改为项目名称;
  4. exportOptionsPlist 此处需要填写上文提到的exportOptionsPlist.plist文件所在目录;
  5. exportFilePath 导出ipa文件路径,默认设置桌面;

你可能感兴趣的:(XCode9制作一键打包脚本)