iOS使用fastlane一鍵打包審核
毋庸置疑,Jenkins對(duì)我們打包的幫助還是很大的——被測(cè)試的同學(xué)追著要IPA包的日子終于一去不復(fù)返了。但作為追求效率的開發(fā)我們僅僅滿足于此就可以了嗎,想想我們iOS開發(fā)遇到的其他諸多類似的問題吧
團(tuán)隊(duì)成員一不小心Revoke了證書導(dǎo)致所有的開發(fā)小伙伴需要重新下載證書,每次提交App Store審核需要重復(fù)【修改證書】- 【打包】-【iTunes Connect】- 【發(fā)布】等一系列動(dòng)作真的是不厭其煩,讓人抓狂。這個(gè)時(shí)候,幸好Fastlane來了,看他怎么來拯救我們吧。在開始我們的教程之前,筆者先做個(gè)澄清,fastlane不是什么:
- fastlane 不是一個(gè)工具,而是一系列工具的集合。比如match工具能管理證書,deliver能提交APPStore審核。所以我們?cè)谑褂胒astlane的時(shí)候更多的是和它的工具集打交道。
- fastlane內(nèi)部的工具不是新寫的,而是調(diào)用mac本身的命令,只不過是實(shí)現(xiàn)了自動(dòng)化而已。比如gym工具只是xcodebuild工具的一個(gè)封裝,如果你會(huì)xcodebuild,那gym對(duì)你來說小菜一碟。
- fastlane本身沒有一套特殊語法,使用的Ruby語言,相信使用過cocoapods的同學(xué)應(yīng)該很容易上手。
安裝完fastlane并調(diào)用fastlane init后,目錄結(jié)構(gòu)大概如下所示:
具體的安裝和初始化,本文稍后會(huì)詳細(xì)講述,先帶大家分析一下安裝后的fastlane的目錄結(jié)構(gòu)。紅色區(qū)域就是多出來的文件。
- Gemfile 告訴我們fastlane 依賴的gem以及版本等其他信息。這個(gè)跟本文主題不大,筆者就不詳細(xì)描述了
- fastlane文件夾里的Appfile看文件也知道,里面是關(guān)于本App的信息的;Fastfile則是fastlane的最主要的文件,在這個(gè)文件中可以編寫我們需要使用的各個(gè)工具的順序、方式等。
這里我們先看一個(gè)已經(jīng)寫好的fastlane的內(nèi)容:
default_platform(:ios)
platform :ios do
desc "Deion of what the lane does"
lane :custom_lane do
# add actions here: https://docs.fastlane.tools/actions
match(
git_url: "https://github.com/zjh171/fastlaneProvingProfile",
type: "appstore" ,
readonly: true
)
gym(
scheme:"Wallpaper",
export_method:"app-store",
output_directory:"./build",
archive_path:"./Archive"
)
end
end
這里我們只需要關(guān)注 match 和gym這兩個(gè)工具以及括號(hào)后的內(nèi)容。match工具是我們本文開頭描述的用于同步開發(fā)小伙伴證書的工具,而gym則是xcodebuild工具的封裝,它指定了打包的目錄以及打包的類型。保存該文件并執(zhí)行fastlane custom_lane后我們可看到
這就表明我們打的App Store包已經(jīng)生成了。目錄就是我們指定的output_directory對(duì)應(yīng)的目錄。當(dāng)然大家也不難猜想到,如果要讓fastlane實(shí)現(xiàn)自動(dòng)提交到App Store審核,還需要在gym后面加上我們需要的工具。這里先賣個(gè)關(guān)子,稍后告訴大家。下面筆者就詳細(xì)的介紹一下fastlane的使用。
安裝
執(zhí)行命令sudo gem install fastlane --verbose即可,安裝完成后檢查一下是否安裝成功輸入fastlane --version看是否有版本號(hào)顯示。
初始化
輸入命令fastlane init會(huì)看到如下選項(xiàng)
What would you like to use fastlane for?
1. Automate screenshots
2. Automate beta distribution to TestFlight
3. Automate App Store distribution
4. Manual setup - manually setup your project to automate your tasks
這四個(gè)選項(xiàng)的意思是
- 自動(dòng)截屏。這個(gè)功能能幫我們自動(dòng)截取APP中的截圖,并添加手機(jī)邊框(如果需要的話),我們這里不選擇這個(gè)選項(xiàng),因?yàn)槲覀兊捻?xiàng)目已經(jīng)有圖片了,不需要這里截屏。
- 自動(dòng)發(fā)布beta版本用于TestFlight,如果大家有對(duì)TestFlight不了解的,可以參考王巍寫的這篇文章
- 自動(dòng)的App Store發(fā)布包。我們的目標(biāo)是要提交審核到APP Store,按道理應(yīng)該選這個(gè),但這里我們先不選,因?yàn)檫x擇了以后會(huì)需要輸入用戶名密碼,以及下載meta信息,需要花費(fèi)一定時(shí)間,這些數(shù)據(jù)我們可以后期進(jìn)行配置。
- 手動(dòng)設(shè)置。
選擇第四個(gè)后一路回車即可,我們會(huì)看到生成了我們熟悉的fastlane目錄,該目錄下包含了Appfile和Fastfile。我們打開這兩個(gè)文件。
Appfile
# app_identifier("[[APP_IDENTIFIER]]") # The bundle identifier of your app
# apple_id("[[APPLE_ID]]") # Your Apple email address
# For more information about the Appfile, see:
# https://docs.fastlane.tools/advanced/#appfile
發(fā)現(xiàn)里面沒有任何信息(“#”在ruby里是注釋,所以里面沒有任何信息)注釋的部分中,app_identifier用于指定APP的bundle id,apple_id指的是你的AppleID。
Fastfile
# Uncomment the line if you want fastlane to automatically update itself
# update_fastlane
default_platform(:ios)
platform :ios do
desc "Deion of what the lane does"
lane :custom_lane do
# add actions here: https://docs.fastlane.tools/actions
end
end
這個(gè)文件的信息稍微多一點(diǎn),而且我們也更熟悉了,語法跟cocoapods很像,而且我們?cè)谖恼麻_頭已經(jīng)稍微做了一些介紹,發(fā)現(xiàn)在lane :custom_lane do后面是空的。其實(shí)意思也就是說,這里任何操作都沒有執(zhí)行。
運(yùn)行
雖然這是個(gè)什么都沒有做的fastlane項(xiàng)目,但其實(shí)我們可以運(yùn)行了,執(zhí)行fastlane custom_lane命令,我們可以看到如下輸出
fastlane detected a Gemfile in the current directory however it seems like you don't use `bundle exec` to launch fastlane faster, please use
$ bundle exec fastlane custom_lane
//此處省略多行
fastlane.tools finished successfully
大致意思就是,我們可以使用命令bundle exec fastlane custom_lane代替fastlane custom_lane,這樣會(huì)執(zhí)行的更快。最后的fastlane.tools finished successfully表示執(zhí)行成功了。
打包
提交審核的前一步是打包,也是最主要的一步fastlane中有專門用于編譯、打包的命令gym,我們加到lane :custom_lane do后看看會(huì)不會(huì)有問題。
然后執(zhí)行fastlane custom_lane我們會(huì)收到如下提示
Select Scheme:
1. Wallpaper
2. AFNetworking
3. Mangogo
4. Masonry
5. MJRefresh
6. Pods-Wallpaper
?
毫無疑問我們選擇1,其他的都是我們調(diào)用的三方庫。但聰明的讀者肯定在想,這個(gè)Scheme是否能在fastlane文件中就設(shè)置好,省的這里在自己選擇。是的,這就是文章開頭提到的
gym(
scheme:"Wallpaper",
export_method:"app-store",
output_directory:"./build",
archive_path:"./Archive"
)
中scheme:"Wallpaper",的含義。其他的參數(shù)也就不一一贅述了。讀到這里,相信大部分讀者已經(jīng)對(duì)fastlane的原理一清二楚了。其實(shí)所謂的會(huì)用fastlane也就是會(huì)用里面的各種工具而已。我相信大家選完Scheme后還沒到打包這一步,應(yīng)該已經(jīng)出現(xiàn)了錯(cuò)誤提示,錯(cuò)誤應(yīng)該就是大家都非常熟悉的證書問題;當(dāng)然,如果讀者夠僥幸,證書已經(jīng)設(shè)置好了,并將output_directory、archive_path設(shè)置好了,那就能生成對(duì)應(yīng)的對(duì)應(yīng)的IPA包。但相信成功的讀者應(yīng)該寥寥無幾,這個(gè)時(shí)候就要使出我們的大殺器match
證書管理
fastlane中能管理證書和簽名的工具其實(shí)還有sigh以及cer,那為何筆者要給大家推薦match呢,原因已經(jīng)在文章開頭指出了,對(duì)于多人開發(fā)時(shí)出現(xiàn)的證書錯(cuò)亂問題match可以很好的處理。它將開發(fā)人員的證書提交到一個(gè)git倉(cāng)庫進(jìn)行集中處理,在有新的成員加入開發(fā)時(shí)候,只需要運(yùn)行一兩條命令。下面我就詳細(xì)講一下其實(shí)現(xiàn)過程吧:
1.創(chuàng)建一個(gè)倉(cāng)庫(空倉(cāng)庫或者現(xiàn)有倉(cāng)庫都可以,但建議大家使用一個(gè)空倉(cāng)庫專門處理證書),這里筆者的倉(cāng)庫地址是:https://github.com/zjh171/fastlaneProvingProfile
2.在終端運(yùn)行fastlane match init可以看到需要我們輸入giturl地址,我們將地址拷進(jìn)來即可。
輸入地址后我們會(huì)看到如下提示
You can now run `fastlane match development`, `fastlane match adhoc`, `fastlane match enterprise` and `fastlane match appstore
我們按照提示生成development和App Store證書,然后會(huì)在Xcode中發(fā)現(xiàn)生成的證書以及Provision Profile文件。我們?cè)赬code中設(shè)置好即可。
接下來,我們將match添加到fastlane文件中,如下
當(dāng)然,這個(gè)文件我們已經(jīng)在文章開頭看過了,是不是再次感覺豁然開朗。回到命令行,我們?cè)俅螆?zhí)行fastlane custom_lane發(fā)現(xiàn)我們可愛的IPA包已經(jīng)打包完畢。
提交App Store審核
終于到了最令人激動(dòng)的提交App Store時(shí)刻了。我們要使用的工具是deliver。聰明的你應(yīng)該已經(jīng)知道,第一步肯定是要調(diào)用fastlane deliver init,這里會(huì)讓我們輸入APPle ID,輸入以后就看到我們的項(xiàng)目文件夾發(fā)生了變化:
接著,我們修改一下fastfile文件,添加deliver,因此我們最終版的fastlane文件是這樣的:
lane :release do
# 增加build版本號(hào)
increment_build_number
match(
git_url: "https://github.com/zjh171/fastlaneProvingProfile",
type: "appstore" ,#can be appstore,adhoc, development,enterprise
app_identifier:"cn.kyson.wallpaper",
username:"[email protected]",
readonly: true
)
# 編譯代碼
gym(
scheme:"Wallpaper",
export_method:"app-store",
)
# 發(fā)布到Apple Store
deliver
end
可以看到,大部分配置跟以前一樣,只做了lane名的改變,還有添加了increment_build_number這一行。increment_build_number的作用是防止本地版本的build號(hào)比App Store(或上次)低而做的自動(dòng)增長(zhǎng)版本號(hào)的處理。

責(zé)任編輯:售電衡衡
-
權(quán)威發(fā)布 | 新能源汽車產(chǎn)業(yè)頂層設(shè)計(jì)落地:鼓勵(lì)“光儲(chǔ)充放”,有序推進(jìn)氫燃料供給體系建設(shè)
2020-11-03新能源,汽車,產(chǎn)業(yè),設(shè)計(jì) -
中國(guó)自主研制的“人造太陽”重力支撐設(shè)備正式啟運(yùn)
2020-09-14核聚變,ITER,核電 -
探索 | 既耗能又可供能的數(shù)據(jù)中心 打造融合型綜合能源系統(tǒng)
2020-06-16綜合能源服務(wù),新能源消納,能源互聯(lián)網(wǎng)
-
新基建助推 數(shù)據(jù)中心建設(shè)將迎爆發(fā)期
2020-06-16數(shù)據(jù)中心,能源互聯(lián)網(wǎng),電力新基建 -
泛在電力物聯(lián)網(wǎng)建設(shè)下看電網(wǎng)企業(yè)數(shù)據(jù)變現(xiàn)之路
2019-11-12泛在電力物聯(lián)網(wǎng) -
泛在電力物聯(lián)網(wǎng)建設(shè)典型實(shí)踐案例
2019-10-15泛在電力物聯(lián)網(wǎng)案例
-
新基建之充電樁“火”了 想進(jìn)這個(gè)行業(yè)要“心里有底”
2020-06-16充電樁,充電基礎(chǔ)設(shè)施,電力新基建 -
燃料電池汽車駛?cè)雽こ0傩占疫€要多久?
-
備戰(zhàn)全面電動(dòng)化 多部委及央企“定調(diào)”充電樁配套節(jié)奏
-
權(quán)威發(fā)布 | 新能源汽車產(chǎn)業(yè)頂層設(shè)計(jì)落地:鼓勵(lì)“光儲(chǔ)充放”,有序推進(jìn)氫燃料供給體系建設(shè)
2020-11-03新能源,汽車,產(chǎn)業(yè),設(shè)計(jì) -
中國(guó)自主研制的“人造太陽”重力支撐設(shè)備正式啟運(yùn)
2020-09-14核聚變,ITER,核電 -
能源革命和電改政策紅利將長(zhǎng)期助力儲(chǔ)能行業(yè)發(fā)展
-
探索 | 既耗能又可供能的數(shù)據(jù)中心 打造融合型綜合能源系統(tǒng)
2020-06-16綜合能源服務(wù),新能源消納,能源互聯(lián)網(wǎng) -
5G新基建助力智能電網(wǎng)發(fā)展
2020-06-125G,智能電網(wǎng),配電網(wǎng) -
從智能電網(wǎng)到智能城市
-
山西省首座電力與通信共享電力鐵塔試點(diǎn)成功
-
中國(guó)電建公司公共資源交易服務(wù)平臺(tái)摘得電力創(chuàng)新大獎(jiǎng)
-
電力系統(tǒng)對(duì)UPS的技術(shù)要求