受安卓之启发,在Xcode有些编译运行过程中,脚本化要比IDE快一些,也本着学习Xcode运行过程的方向,记录一些学习的过程,在初写此博客时,只学一点,记一点
- 系统 macOS10.12.6
- 工具 Xcode8.2.1 及 Xcode9.1
编译
终端先进入项目路径
切换Xcode版本
对于
- 电脑中装了多个版本的编译器
- 且项目在不同版本Xcode的下编译运行的,需要切换到对应的Xcode
- 我的两个Xcode都在/Applications路径下,通过名称相区别,如果你的Xcode是采取不同路径,那么是先进入的Xcode路径,后边命令加上/Contents/Developer,完整命令如下:
- sudo xcode-select -s /Applications/Xcode.app/Contents/Developer
- 查看当前编译版本 xcodebuild -version
添加 team
这一点有点奇怪,对于命令编译必须要在Xcode中配置好team,如果是自己练习项目,可以随便找一个开发者账号配置一个team,私人的无证书的账号也可以,不然会team和签名错误无workspace项目
对于没有没有集成pod的项目,也就是步存在workspace的项目,可以在项目路径直接执行Xcodebuild,就可以编译成功,其中参数
- -project preject 路径,即xx.xcodeproj的路径
- -scheme 一般为项目的名字,具体是设置在这里
对于已经设置schme的项目,可以通过Xcodebuild -list去查询,找最下面的Schemes
- -configuration 区别是debug版本还是release版本,值分别为Debug 和 Release
- -alltargets 直接写就好
---编译命令为---
xcodebuild -project 5cell.xcodeproj -scheme 5cell
包含workspace项目
此时Xcodebuild 要加两个参数
- -workspace 后面加workspace的路径,如果已经cd到项目路径下了,那么直接加workspace全名就好,即项目名.workspace
- -scheme 不在赘述
- -configuration 不在赘述
---完整编译命令为:---
xcodebuild -workspace 5cell.xcworkspace -scheme 5cell -configuration Release
clean
- 在编译的命令 的xcodebuilde 后面加上clean,类似于以下这样
- xcodebuild clean -workspace 5cell.xcworkspace -scheme 5cell -configuration Release
- 依旧区分是不是workspace的项目
归档
命令为 xcodebuild archive,参数为:
- -workspace 不在赘述,和上面的编译的时候是一样的
- -scheme 不在赘述
- -configuration 不在赘述
- -archivePath 要到处的归档文件的路径,一般最后一级路径为 项目名.xcarchive其中.xcarchive要看做是一个文件夹而不是文件,所以要手动的创建一个项目名.xcarchive**
- -destination 值为 generic/platform=ios
导出IPA
命令为 xcodebuild -exportArchive,参数为
- -archivePath 归档出来的xcarchive的全路径
- -exportPath 导出IPA的路径,这个领随意
- -destination 不赘述,和上一步一样的
- exportOptionsPlist 配置plist路径,这个马上详述
---大致命令如下---
xcodebuild -exportArchive -archivePath /XXX/xxx.xcarchive -exportPath /XXX/ipa -destination generic/platform=ios
-exportOptionsPlist /XXXX/ExportOptions.plist
配置文件
这个配置文件各种百度谷歌也没有太确定的答案,只是知道一些配置信息,包括证书,已经打包的渠道用处,但是具体的键值不太明白
后来有博客提示先利用Xcode9导出IPA,会有此配置文件,现在将文件具体键值罗列如下
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>compileBitcode</key>
<true/>
<key>method</key>
<string>development</string>
<key>signingStyle</key>
<string>automatic</string>
<key>stripSwiftSymbols</key>
<true/>
<key>teamID</key>
<string>XXXXX</string>
<key>thinning</key>
<string><thin-for-all-variants></string>
</dict>
</plist>
- method 取值为
- app-store
- enterprise
- ad-hoc
- development
-
teamID
这个是证书的一个标识码,可以在开发者证书中看到,大致为一下图片中我标红的部分
- compileBitcode 是否开启bitcode
- signingStyle 为Xcode9的一些特性,暂不做解释,后续解释
错误
-
错误主要图如下
- 各种谷歌百度了一下偶发现答案,执行一下命令
- sudo gem install CFPropertyList
- rvm use system
版本
以上博客是针对Xcode8.2.1的编译器,Xcode9的编译器导出IPA的配置文件键值有一定的修改,如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>method</key>
<string>app-store</string>
<key>provisioningProfiles</key>
<dict>
<key>XXX</key>
<string>XXXXXX</string>
</dict>
<key>signingCertificate</key>
<string>iPhone Distribution</string>
<key>signingStyle</key>
<string>manual</string>
<key>stripSwiftSymbols</key>
<true/>
<key>teamID</key>
<string>****</string>
<key>uploadBitcode</key>
<false/>
<key>uploadSymbols</key>
<true/>
</dict>
</plist>
增加了provisioningProfile和** uploadSymbols**等标识,后续对这些键值做详细的解释补充
参考