iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)

闲话不说,直接来干货。
内容概况 1.shell 打包导出ipa 包,自动上传 App Store、蒲公英、Fir等
今日亲测验证 xcode11 下,App Store上传成功,蒲公英上传成功复制代码
2.准备工作
脚本文件、检测证书匹配性 拿到需要用到的各平台参数复制代码
3.打包过程中遇到的问题及解决方案
针对xcode10和xcode11出来的一些问题的特别说明其他问题复制代码
4.参考文献
之前收藏的几篇不错的博客,供大家一起分享学习。复制代码
5.延续看图说话的方式进行分享。

操作步骤
涉及到的文件有3个:
脚本文件:https://github.com/kepuna/archiveScript


iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
涉及的脚本文件 将这3个文件放到工程内,具体安放位置见下图:


iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
脚本文件存放位置 其中exportAppStore.plist 也做了相应的修改,具体见图:


iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
上传App Store plist文件修改 exportTest.plist 具体内容见图:


iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
上传蒲公英之类的平台的plist文件 备注一下:我在:https://github.com/kepuna/archiveScript 这个基础上进行了改造,需要注意的点都进行了详细的备注,改造内容如下:
#使用方法
if[ ! -d ./IPADir ];
then
mkdir -p IPADir;
fi
#工程绝对路径
project_path=$(cd`dirname $0`; pwd)
#工程名 将XXX替换成自己的工程名
【iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)】project_name= XXX
#scheme名 将XXX替换成自己的sheme名
scheme_name=XXX
#打包模式 Debug/Release
development_mode=Debug
#build文件夹路径
build_path=${project_path}/build
#plist文件所在路径
exportOptionsPlistPath=${project_path}/exportTest.plist
#导出.ipa文件所在路径
exportIpaPath=${project_path}/IPADir/${development_mode}
echo "Place enter the number you want to export ? [ 1:app-store 2:ad-hoc] "
##
readnumber
while([[ $number !=1]] && [[ $number !=2]])
do
echo "Error! Should enter 1 or 2"
echo "Place enter the number you want to export ? [ 1:app-store 2:ad-hoc] "
readnumber
done
if[ $number ==1]; then
development_mode=Release
exportOptionsPlistPath=${project_path}/exportAppstore.plist
else
development_mode=Debug
exportOptionsPlistPath=${project_path}/exportTest.plist
fi
echo '///-----------'
echo '/// 正在清理工程'
echo '///-----------'
xcodebuild \
clean -configuration ${development_mode} -quiet||exit
echo '///--------'
echo '/// 清理完成'
echo '///--------'
echo ''
echo '///-----------'
echo'/// 正在编译工程:'${development_mode}
echo '///-----------'
# UseModernBuildSystem 编译模式,NO 采用传统的(legacy build system),YES采用现在的(new build system)
# 工程里面有pod 使用 archive -workspace ${project_path}/${project_name}.xcworkspace
# 工程里面没有pod 使用archive -project ${project_name}.xcodeproj
xcodebuild \
-UseModernBuildSystem=NO \
archive -workspace ${project_path}/${project_name}.xcworkspace \
-scheme ${scheme_name} \
-configuration ${development_mode} \
-archivePath ${build_path}/${project_name}.xcarchive-quiet||exit
echo '///--------'
echo '/// 编译完成'
echo '///--------'
echo ''
echo '///----------'
echo '/// 开始ipa打包'
echo '///----------'
xcodebuild -exportArchive -archivePath ${build_path}/${project_name}.xcarchive \
-configuration ${development_mode} \
-exportPath ${exportIpaPath} \
-exportOptionsPlist ${exportOptionsPlistPath} \
-quiet ||exit
if[ -e $exportIpaPath/$scheme_name.ipa ]; then
echo '///----------'
echo '/// ipa包已导出'
echo '///----------'
open $exportIpaPath
else
echo '///-------------'
echo '/// ipa包导出失败 '
echo '///-------------'
fi
echo '///------------'
echo '/// 打包ipa完成'
echo '///-----------='
echo ''
echo '///-------------'
echo '/// 开始发布ipa包 '
echo '///-------------'
if[ $number ==1]; then
#验证并上传到App Store
# 将-u 后面的XXX替换成自己的AppleID的账号,-p后面的XXX替换成自己的密码
#altoolPath="/Applications/Xcode.app/Contents/Applications/Application Loader.app/Contents/Frameworks/ITunesSoftwareService.framework/Versions/A/Support/altool"
#"$altoolPath" --validate-app -f ${exportIpaPath}/${scheme_name}.ipa -u "XXXXXXXXX" -p "XXXXXXX" -t ios --output-format xml
#"$altoolPath" --upload-app -f ${exportIpaPath}/${scheme_name}.ipa -u"XXXXXXX" -p "XXXXXXX" -t ios --output-format xml
# 验证并上传到APP Storexcode11之后方法验证成功
# apiKey apiIssuer苹果后台找下面用XXXXX 代替
xcrun altool --validate-app -f ${exportIpaPath}/${scheme_name}.ipa -t ios --apiKey"XXXXX"--apiIssuer"XXXXXXXXXX-XXXXX-XXXXX-XXXXX-XXXXXXXXXX"--verbose
xcrun altool --upload-app -f ${exportIpaPath}/${scheme_name}.ipa -t ios --apiKey"XXXXX"--apiIssuer"XXXXXXXXXX-XXXXX-XXXXX-XXXXX-XXXXXXXXXX"--verbose
else
##上传到Fir没有进行实名认证,暂不验证
## 将XXX替换成自己的Fir平台的token
#fir login -T XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
#fir publish $exportIpaPath/$scheme_name.ipa
#上传蒲公英成功验证
#uKey_api_key 将用XXXXX代替,在蒲公英里面找
echo '/+++++++ 上传蒲公英 +++++++/'
curl -F"file=@$exportIpaPath/$scheme_name.ipa"\
-F "uKey=XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX" \
-F "_api_key=XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX" \
https://qiniu-storage.pgyer.com/apiv1/app/upload
append_path="已上传到蒲公英"
mv $exportIpaPath $exportIpaPath$append_path
echo '/+++++++ 成功上传到蒲公英 +++++++/'
fi
exit 0
补充:运行shell脚本:


iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
运行脚本 需要特别提醒的地方
1.编译模式
2.工程中是否有pod
3.上传App Store的时候,注意xcode11 前后的命令不同
4.关于两个plist中需要注意的地方
5.操作完一次,我们工程里面跟我们导入的3个文件同路径下会生成2个文件,再下次再进行打包前需要删掉,否则clean不成功,也就不会继续打包了。
如果你的工程编译方式使用的是legacy build system 这种方式,那么我们需要做下面的操作,因为我们打包的时候,这里默认是new build system。


iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
编译模式和是否有pod

iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
xcode11前后打包命令 xcode11之后,我们打包的时候,需要使用密钥,这个过程中多了2个参数,同时还需要一个文件作为必备条件,我们这2个参数和文件的来源,见下图:


iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
xcode11使用密钥打包

iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
测试用的pilst文件修改

iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
App Store上传的plist文件修改

iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
特别提醒的第五个问题 蒲公英打包的时候,需要用到的2个参数来源,见下图:


iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
蒲公英参数 常出现的一些报错问题,列举几个典型的。尤其是xcode11的问题
1.由编译模式问题引起的问题,解决方法上面截图已写
ld: library not found for -lAFNetworking clang: error: linker command failed with exit code 1 (use -v to see invocation)
2.xcode11 打包的时候,在没有正确存放.private_keys 文件时候,会报下面错误
Could not find private key file: AuthKey_5ZGKY5BF7J.p8, in any of the following locations. ./private_keys or /private_keys or /.private_keys or /.appstoreconnect/private_keys 以下任何位置找不到私钥文件:AuthKey_XXXXX.p8。
./private_keys或<用户主目录> / private_keys或<用户主目录> /。private_keys或<用户主目录> /。appstoreconnect / private_keys
Could not find private key file: AuthKey_4PBMS86V4B.p8, in any of the following locations.




iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
xcode11打包问题 这个问题的具体解决方案上面已经截图了,这次再发一遍。这块容易出错。
补充:隐藏文件.private_keys 需要注意的点: 如果我们的根目录,没有显示出隐藏文件,那么我们可以使用下面两种方式让其显示根目录。

第一种:
在 macOS Sierra及以上(Mojave),我们可以使用快捷键 ??.(Command + Shift + .) 来快速(在 Finder 中)显示和隐藏隐藏文件了。
第二种:
在终端使用:
//显示隐藏文件defaults write com.apple.finder AppleShowAllFiles -booltrue
//不显示隐藏文件defaults write com.apple.finder AppleShowAllFiles -boolfalse
最后需要重启Finder:
重启Finder:窗口左上角的苹果标志-->强制退出-->Finder-->重新启动
显示隐藏文件之后,我们就可以在根目录进行创建.private_keys 文件了。
iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
处理Private文件

iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
运行正常 3.证书相关问题 这个具体问题需要具体分析,保证 证书匹配就好了


iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
证书问题 成功上传蒲同英


iOS|iOS 高效开发必备技巧之自动化打包(shell xcode11 上传App Store 蒲公英等平台)
文章图片
蒲公英上传成功 不错的一些博客分享,这里有自动打包过程中遇到的其他问题,我们可以参考学习
http://www.cocoachina.com/articles/26201
掘金中的 daisyduan 也是我啊 , https://juejin.im/post/5e0373dd6fb9a01627128e2e
https://juejin.im/post/5e03370f6fb9a01633075326
https://juejin.im/post/5e05fbfe6fb9a0163514e9e9

    推荐阅读