iOS自動(dòng)化打包 ---- 集成shell腳本

在閱讀這篇文章之前
如果有小伙伴還不是很清楚xcodebuild命令的話(huà)
建議查看iOS自動(dòng)化打包 ---- xcodebuild 命令詳解

在具備基本知識(shí)之后
我們就可以用xcodebuild為所欲為啦~

第一步:

我們?yōu)榱诉_(dá)到腳本 write once,run anywhere
需要配置一些變量

##!/bin/sh

# 工程絕對(duì)路徑  (這里注意是shell腳本所在的路徑)
project_path=$(cd "$(dirname "$0")";pwd)

# 工程名
project_name=<your project name>

# Scheme名 
project_scheme=<your scheme name>

# 編譯模式
build_type=Debug

# workspace名
project_workspace=<your workspace path>

# archive_path        eg:$project_path/$project_name.xcarchive
archive_path=<your archive path>

# ipa文件存放路徑        eg:$project_path/$project_name.ipa
export_ipa_path=<your export ipa path>

# exportOptions plist       eg:$project_path/ExportOptions.plist
export_options_plist=<your export options plist>

這里說(shuō)明一下ExportOptions.plist
這個(gè)東西我們正常使用xcode打包導(dǎo)出ipa的時(shí)候會(huì)生成
記錄了這次導(dǎo)出時(shí)的證書(shū)關(guān)鍵配置
我們可以第一次手動(dòng)導(dǎo)出查看里面結(jié)構(gòu)信息

image.png

后續(xù)根據(jù)需要打包導(dǎo)出的需求做調(diào)整

第二步:

就是 清理工程-->打包-->導(dǎo)出 三部曲
我們有三種類(lèi)型的導(dǎo)出方式 dev、adhoc、dis
所以我這邊通過(guò)輸入?yún)?shù)的方式來(lái)配置三種類(lèi)型

echo "--------------------------------------------------------------------------------"
echo "Please enter the number you want to export ? [ 1:app-store 2:ad-hoc 3:develop ] "
echo "--------------------------------------------------------------------------------"

read number
while [[ $number != 1 ]] && [[ $number != 2 ]] && [[ $number != 3 ]]; do
    #statements
    echo "Error! Should enter 1 or 2 or 3"
    echo "Please enter the number you want to export ? [ 1:app-store 2:ad-hoc 3:develop ] "
    read number
done

if [[ $number == 1 ]]; then
    build_type=Release
    export_options_plist=$project_path/ExportOptions_appstore.plist
elif [[ $number == 2 ]]; then
    build_type=Release
    export_options_plist=$project_path/ExportOptions_adhoc.plist
else
    build_type=Debug
    export_options_plist=$project_path/ExportOptions_dev.plist
fi

中間的export_options_plist根據(jù)各自工程情況自己配好對(duì)應(yīng)名稱(chēng),方便切換

echo "http:///-----------"
echo "http:/// 正在清理工程"
echo "http:///-----------"
xcodebuild clean -workspace $project_workspace -scheme $project_scheme -configuration $build_type -quiet || exit

echo "http:///-----------"
echo "http:/// 正在編譯工程: ${build_type}"
echo "http:///-----------"
xcodebuild archive -workspace ${project_workspace} -scheme ${project_scheme} -configuration $build_type -archivePath $archive_path || exit

echo "http:///-----------"
echo "http:/// 開(kāi)始導(dǎo)出ipa: ${export_ipa_path}"
echo "http:///-----------"
xcodebuild -exportArchive -archivePath $archive_path -exportPath ${export_ipa_path} -exportOptionsPlist ${export_options_plist} -quiet || exit

校驗(yàn)ipa包是否導(dǎo)出

if [[ -e $export_ipa_path/$project_scheme.ipa ]]; then
    echo "http:///-----------"
    echo "http:/// ipa包已導(dǎo)出"
    echo "http:///-----------"
    open $export_ipa_path
fi

到這里,我們的打包大業(yè)已經(jīng)完成啦~
打好包后,我們可以使用第三方平臺(tái)托管我們的包,以便提供測(cè)試人員掃碼下載
也可以上傳AppStore
這里我們用的是蒲公英平臺(tái),其他平臺(tái)可以參照對(duì)應(yīng)文檔作調(diào)整

第三步:

if [[ $number == 1 ]]; then

    echo "http:///--------------------"
    echo "http:/// 開(kāi)始發(fā)布到 app store"
    echo "http:///--------------------"

    altoolPath=/Applications/Xcode.app/Contents/Applications/Application\ Loader.app/Contents/Frameworks/ITunesSoftwareService.framework/Support/altool
    "$altoolPath" --validate-app -f $export_ipa_path/$project_scheme.ipa\
                  -u <你的開(kāi)發(fā)者賬號(hào)> -p <你的開(kāi)發(fā)者賬號(hào)密碼>\
                  --output-format xml
    "$altoolPath" --upload-app -f $export_ipa_path/$project_scheme.ipa\
                  -u <你的開(kāi)發(fā)者賬號(hào)> -p <你的開(kāi)發(fā)者賬號(hào)密碼>\
                  --output-format xml
else

    echo "http:///--------------------"
    echo "http:/// 開(kāi)始上傳ipa包到蒲公英"
    echo "http:///--------------------"
    curl -F "file=@$export_ipa_path/$project_scheme.ipa"\
         -F "uKey=<你的蒲公英uKey>"\
         -F "_api_key=<你的蒲公英ApiKey>" https://qiniu-storage.pgyer.com/apiv1/app/upload
fi

$altoolPath 是xcode自帶的Application Loader 的命令行,可以完成提交到App Store Connect操作,剩下的就坐等審核啦!

2019年11月04日 新增修改

更新完xcode11 之后,很多小伙伴發(fā)現(xiàn)曾經(jīng)的Application Loader 不見(jiàn)了
其實(shí)是蘋(píng)果為了推新的Transporter,大家可以去AppStore搜索下載
看評(píng)論是褒貶不一,優(yōu)化了用戶(hù)體驗(yàn),但是據(jù)說(shuō)速度很慢

既然是自動(dòng)化打包,那么上傳還是用腳本來(lái)完成吧
老的altool的命令,被集成進(jìn)了xcode里
大家可以輸入下面的命令查看新的打包腳本,和老的沒(méi)什么出入,換了前綴而已

$ xcrun altool

修改后的AppStore的上傳腳本

xcrun altool --validate-app -f $export_ipa_path/$project_scheme.ipa\
                  -u <你的開(kāi)發(fā)者賬號(hào)> -p <你的開(kāi)發(fā)者賬號(hào)密碼>\
                  --output-format xml
xcrun altool --upload-app -f $export_ipa_path/$project_scheme.ipa\
                  -u <你的開(kāi)發(fā)者賬號(hào)> -p <你的開(kāi)發(fā)者賬號(hào)密碼>\
                  --output-format xml

當(dāng)然,還有一種操作就是保留xcode 10.3的Application Loader 然后拷貝到xcode11的對(duì)應(yīng)目錄下,重啟xcode也可以達(dá)到同樣的效果

2019年11月19日 新增修改

蒲公英更新了接口文檔,清理掉了之前所有的內(nèi)測(cè)包
原本的腳本上傳會(huì)報(bào)下面的錯(cuò)誤

210 installType error

查閱信息,并且手動(dòng)上傳之后發(fā)現(xiàn)

installType不再支持公開(kāi)的方式了

因?yàn)樵瓉?lái)默認(rèn)是傳1的,所以被底層上傳接口攔截掉了
所以我們需要在上傳腳本中加上installType才可以成功上傳
如果選了2:密碼安裝,按需加上password字段
可能也是為了安全起見(jiàn)吧,要求密碼字段不能為空
修改之后的蒲公英上傳腳本:

curl -F "file=@$export_ipa_path/$project_scheme.ipa"\
         -F "uKey=d718feb45b310ea811a3f59bf04cca2b"\
         -F "_api_key=82af289e7129f483befc42e6b7ba2443"\
         -F "installType=<2 || 3>"\
         -F "password=<你的密碼>" https://upload.pgyer.com/apiv1/app/upload

2019年12月26日 新增修改

以前導(dǎo)出的ExportOptions.plist文件中,因?yàn)樯?jí)XCode ,加上iOS13之后證書(shū)都合一了,稱(chēng)為Apple DevelopmentApple Distribution,同時(shí)文件里對(duì)應(yīng)的profile文件的地方也要同步更新,不然導(dǎo)出會(huì)報(bào)錯(cuò)

有什么疑問(wèn),歡迎留言討論
以上

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容