IOS自动化打包介绍

简介:

摘要

随着苹果手持设备用户的不断增加,ios应用也增长迅速,同时随着iphone被越狱越来越多的app 的渠道也不断增多,为各个渠道打包成了一件费时费力的工作,本文提供一种比较智能的打包方式来减少其带来的各种不便。

TAG

Ios打包,app打包,iphone打包,iphone自动化打包,ios打渠道包,iphone自动化打渠道包

 

自动化打包背景介绍

1、背景

随着ios程序发布的渠道逐渐的增多,为每个渠道打包也成为特别耗费时间和体力的一项技术活了,而这一般大多数都是由rd来完成的。这样就占用了rd很多的开发时间,何不把这些东西写成一个自动化的脚本,然后交给qa 或是 pm来完成这个打包过程了。经过一番调研发现网上这种脚本还是很少的,不过xcode 提供了shell编译工具 xcodebuild 和 ipa打包工具xcrun ,这就有理由让我们利用这两个工具写一个自动化的打包脚本来提高我们的工作效率和自动化程度。

2、ios程序包格式、渠道包格式

1) 产生多渠道的原因及多渠道带来的打包问题:随着iphone、ipad、itouch等手持设备火热销售,而它们上面的应用也随之火爆了起来,而随之而来的就是以上设备被越狱后就可以在越狱的设备上直接运行ipa程序包 而不用通过appstore去下载,这样一来国内就产生了众多的专门为越狱手机而开设的渠道提供ipa程序包的下载。随着越来越多的渠道,推广时为各个渠道打包就成了一项比较耗费时间和精力的技术活了,因此我们必须寻找一种自动化的方式 让打包变得高效简单。
2) Ios程序包分为appstore二进制文件跟渠道包两种格式
appstore二进制文件:通过xcode工具可以生成一个.app格式的二进制文件。
渠道包:格式为.ipa格式,在没有自动化打包工具之前都是利用xcode来生成相应的渠道包,而且每次只能生成一个渠道,每次打包之前都得手动该渠道ID,带来的问题就是耗费时间、效率低下、容易出错、增加风险。

3、传统的ios打包方式

利用xcode 打包

1) appstore 二进制程序包
打开你的项目,进入“Edit Project Settings”,进入Configuration页面,选中Release点击下面的Duplicate,复制一个新的配置项出来,命名为Distribution。然后进入Build页面,顶上的Configuration下拉框选中Distribution,下面的Code Signing Identity里面的Any iPhone OS Device后面对应的值选中你的那个Distribution的证书。然后点击“Build”–> “Build” 就可以编译程序了
编译成功后,你就可以在相应的build目录下看到一个.app的二进制文件。
2) 渠道ipa包
根据以上步骤同样配置好Distribution 证书 ,然后点击 “Build”–> “Build and Archive” 就可以编译程序了。接着打开“Window””Organizer” 左边栏中选择”ARCHIVED APPLICATIONS” 然后再右侧列表中选中刚才编译的程序包 再点击右侧右边顶部的”Share”按钮 保存到磁盘即可。就会生成一个.ipa的文件 即为渠道包。
注意:以上运行设备必须选择“Deveice“

4、传统的打包带来的问题

耗费时间、耗费体力、效率低下、只能依赖RD来完成、容易出错、发布风险比较高、QA回归确认比较困难、 不智能化。

自动化打包具体实现

1、xcodebuild 介绍:

 

    
    
  1. 1 xcodebuild[-project    
  2.  
  3. 2 ][-activetarget][-alltargets][-target]...[-parallelizeTargets][-activeconfiguration][-configuration][-sdk |][=]...[]...    
  4.  
  5. 3 xcodebuild[-version[-sdk |]]    
  6.  
  7. 4 xcodebuild[-showsdks]    
  8.  
  9. 5 xcodebuild[-find ][-sdk |]    
  10.  
  11. 6 xcodebuild[-list]   
  12.  
 
也可以在终端输入:xcodebuild –help 或 –h查看具体的选项
显示xcodebuildversion:xcodebuild –version
显示当前系统安装的sdk:xcodebuild –showsdks
显示当前目录下project Information:xcodebuild –list
需要注意的是:执行以上命令时必须把位置定位在ios项目文件的根目录下 否则会提示找不相关命令的。

2、xcrun 介绍:

此工具主要用于将app文件打包成ipa格式的程序包。(主要用于已越狱手机)。
具体用法如下:

 

   
   
  1. 1 /usr/bin/xcrun -sdk iphoneos PackageApplication –v [{TARGET}.app] -o [{TARGET}.ipa] --sign [{Iphone Distribution:xxx}] –embed [{xxx.mobileprovision}]   
  2.  

其中:-v 对应的是app文件的绝对相对路径 –o 对应ipa文件的路径跟文件名 –sign
对应的是 发布证书中对应的公司名或是个人名  –embed 对应的是发布证书文件
注意如果对应的Distribution 配置中已经配置好了相关证书信息的话 –sign 和 –embed可以忽略

3、具体方案

a) 从源程序一次性打出所有渠道的ipa包 跟appstore的二进制包
为了让自动化脚本执行一次把所有的渠道包都打好,所以必须有一个配置文件用来存储所有的渠道名跟渠道号,而项目文件中也应该有个对应存储当前渠道号的文件,每次程序都从这个存放渠道号的文件中读取渠道号即可,大概的思路就是利用脚本循环执行打包过程,而每次打包前都通过脚本修改项目中存放渠道号的文件为当前循环的最新渠道号,让后逐个打包。
注:具体事例见附录

b) 提供一个ipa格式的母包 从母包生成其它所有的渠道包跟 appstore 包
qa的一些疑问,如何确保所有的渠道包就是他们验证过的那份代码呢?
的确,以上代码每次都是重新对程序进行打包,可qa往往测试验证的只有一个包,如果个个去验证无意中之中又增加了qa的工作量哈!!而且风险也不可控。因此基于上面的问题我们想出了一下办法:qa只验证一个程序包(即母包)如果这个包通过验证 我们就通过母包去生成其它渠道的包,这样一来qa也不用确认那么多的渠道包了,风险也得到了有效的控制。
可能你会问:用一个包生成其他的包可行么??
原因是这样的:因为每个渠道只是渠道号发生变化,而其他的内容又不会发生变化,而我们的渠道号又是存储在sourceid.dat这个文件中的,所以只要改变母包中的sourceid.dat文件的内容即可,而ipa包又是同zip格式进行压缩,所以基本思路就是通过zip先对母包进行解压,然后改变sourceid.dat的内容 最后再用zip进行压缩成相应的渠道包即可。
Ipa包的目录:


注:具体事例见附录

一些问题

当有些shell命令在mac的终端中运行不通过时,请确保你的shell脚本是在mac环境下编写的而不是同xp等其他环境中copy过来的。因为mac跟xp的编码是不一样所以会有问题。

总结:

通过从母包打出其他渠道的包这种方法:得到以下好处

i.              降低了rd的工作量,一起qa的工作量。

ii.              让测试发布程序时的风险得到了控制。

iii.              提高了打包发布工作效率。(几十个包 只需短短的几分钟)。

iv.              提高了自动化。

v.              不依赖mac 以及xcode环境 直接在linux 下即可完成 从母包生成其它包

附录

利用xcode环境一次生成所有包的shell 脚本代码:


   
   
  1. 01 #!/bin/sh    
  2.  
  3. 02      
  4.  
  5. 03 xcodebuild clean -configuration Distribution      //clean项目    
  6.  
  7. 04      
  8.  
  9. 05 distDir="/Users/xxxx/dist"   
  10.  
  11. 06 releaseDir="build/Distribution-iphoneos"   
  12.  
  13. 07 version="1_0_0"   
  14.  
  15. 08 rm -rdf "$distDir"   
  16.  
  17. 09 mkdir "$distDir"   
  18.  
  19. 10 for line in $(cat data.dat)        //读取所有渠道号data.dat文件    
  20.  
  21. 11 do   
  22.  
  23. 12 ipafilename=`echo $line|cut -f1 -d':'` //渠道名    
  24.  
  25. 13 sourceid=`echo $line|cut -f2 -d':'`    //渠道号    
  26.  
  27. 14 echo "ipafilename=$ipaname"   
  28.  
  29. 15 echo "sourceid=$sourceid"   
  30.  
  31. 16 targetName="youtargename"   //项目名称(xcode左边列表中显示的项目名称)    
  32.  
  33. 17 echo "sourceid=$sourceid"   
  34.  
  35. 18 echo "ipafilename=$ipafilename"   
  36.  
  37. 19 echo "$sourceid" > sourceid.dat    
  38.  
  39. 20 echo "sourceid.dat: "   
  40.  
  41. 21 cat sourceid.dat    
  42.  
  43. 22 rm -rdf "$releaseDir"   
  44.  
  45. 23      
  46.  
  47. 24 ipapath="${distDir}/${targetName}_${version}_from_${sourceid}.ipa"   
  48.  
  49. 25      
  50.  
  51. 26 echo "***开始build app文件***"   
  52.  
  53. 27 xcodebuild -target "$targetName" -configuration Distribution  -sdk iphoneos build    
  54.  
  55. 28 appfile="${releaseDir}/${targetName}.app"   
  56.  
  57. 29 if [ $sourceid == "appstore" ]    
  58.  
  59. 30 then   
  60.  
  61. 31 cd $releaseDir    
  62.  
  63. 32 zip -r "${targetName}_${ipafilename}_${version}.zip" "${targetName}.app"   
  64.  
  65. 33 mv "${targetName}_${ipafilename}.zip" $distDir 2> /dev/null    
  66.  
  67. 34 cd ../..    
  68.  
  69. 35 else   
  70.  
  71. 36 echo "***开始打ipa渠道包****"   
  72.  
  73. 37 /usr/bin/xcrun -sdk iphoneos PackageApplication -v "$appfile" -o "$ipapath" --sign "iPhone Distribution:xxxxxx"   
  74.  
  75. 38 fi   
  76.  
  77. 39 done   
  78.  
 
注:以上的data.dat文件为存放渠道号列表的文件 其格式为:3g:1001b 即 (渠道名:渠道号) sourceid.dat 为项目文件中存放渠道号的文件(内容只有一个渠道号)。当然了上面脚本只是说明了下如何利用xcodebuild 和 xcrun 进行打包 以及自动打包的一个逻辑,shell脚本好的同学可以自由发挥哈。。。

从ipa格式的母包生成其它渠道包的shell脚本实例:


    
    
  1. #!/bin/sh
  2. xcodebuild clean -configuration Distribution //clean项目
  3. distDir="/Users/xxxx/dist"
  4. releaseDir="build/Distribution-iphoneos"
  5. version="1_0_0"
  6. rm -rdf "$distDir"
  7. mkdir "$distDir"
  8. for line in $(cat data.dat) //读取所有渠道号data.dat文件
  9. do
  10. ipafilename=`echo $line|cut -f1 -d':'` //渠道名
  11. sourceid=`echo $line|cut -f2 -d':'` //渠道号
  12. echo "ipafilename=$ipaname"
  13. echo "sourceid=$sourceid"
  14. targetName="youtargename" //项目名称(xcode左边列表中显示的项目名称)
  15. echo "sourceid=$sourceid"
  16. echo "ipafilename=$ipafilename"
  17. echo "$sourceid" > sourceid.dat
  18. echo "sourceid.dat: "
  19. cat sourceid.dat
  20. rm -rdf "$releaseDir"
  21. ipapath="${distDir}/${targetName}_${version}_from_${sourceid}.ipa"
  22. echo "***开始build app文件***"
  23. xcodebuild -target "$targetName" -configuration Distribution -sdk iphoneos build
  24. appfile="${releaseDir}/${targetName}.app"
  25. if [ $sourceid == "appstore" ]
  26. then
  27. cd $releaseDir
  28. zip -r "${targetName}_${ipafilename}_${version}.zip" "${targetName}.app"
  29. mv "${targetName}_${ipafilename}.zip" $distDir 2> /dev/null
  30. cd ../..
  31. else
  32. echo "***开始打ipa渠道包****"
  33. /usr/bin/xcrun -sdk iphoneos PackageApplication -v "$appfile" -o "$ipapath" --sign "iPhone Distribution:xxxxxx"
  34. fi
  35. done
注:以上data.dat也是用来存储所有渠道号的,sourceipaname就是通过qa验证的母包,appname为ipa包加压后Payload 目录下的app文件名并且以上所有文件必须与脚本文件保持在同一目录下以及在mac环境中执行。

by liuzhibin

 












本文转自百度技术51CTO博客,原文链接:http://blog.51cto.com/baidutech/742977 ,如需转载请自行联系原作者
相关文章
|
2月前
|
存储 Shell Linux
快速上手基于 BaGet 的脚本自动化构建 .net 应用打包
本文介绍了如何使用脚本自动化构建 `.net` 应用的 `nuget` 包并推送到指定服务仓库。首先概述了 `BaGet`——一个开源、轻量级且高性能的 `NuGet` 服务器,支持多种存储后端及配置选项。接着详细描述了 `BaGet` 的安装、配置及使用方法,并提供了 `PowerShell` 和 `Bash` 脚本实例,用于自动化推送 `.nupkg` 文件。最后总结了 `BaGet` 的优势及其在实际部署中的便捷性。
109 10
|
23天前
|
iOS开发 开发者 MacOS
在线创建ios打包证书无需mac
这个文件并不一定需要使用mac OS去创建,在苹果开发者中心,生成了cer格式的证书后,导出p12证书这个过程,其实也并不一定需要mac电脑来完成。
19 0
|
3月前
|
测试技术 Linux 虚拟化
iOS自动化测试方案(五):保姆级VMware虚拟机安装MacOS
详细的VMware虚拟机安装macOS Big Sur的保姆级教程,包括下载VMware和macOS镜像、图解安装步骤和遇到问题时的解决方案,旨在帮助读者顺利搭建macOS虚拟机环境。
109 3
iOS自动化测试方案(五):保姆级VMware虚拟机安装MacOS
|
3月前
|
测试技术 开发工具 iOS开发
iOS自动化测试方案(三):WDA+iOS自动化测试解决方案
这篇文章是iOS自动化测试方案的第三部分,介绍了在没有MacOS系统条件下,如何使用WDA(WebDriverAgent)结合Python客户端库facebook-wda和tidevice工具,在Windows系统上实现iOS应用的自动化测试,包括环境准备、问题解决和扩展应用的详细步骤。
212 1
iOS自动化测试方案(三):WDA+iOS自动化测试解决方案
|
3月前
|
测试技术 数据安全/隐私保护 iOS开发
iOS自动化测试方案(四):保姆级搭建iOS自动化开发环境
iOS自动化测试方案的第四部分,涵盖了基础环境准备、iPhone虚拟机设置、MacOS虚拟机与iPhone真机的连接,以及扩展问题和代码示例,确保读者能够顺利完成环境搭建并进行iOS自动化测试。
198 0
iOS自动化测试方案(四):保姆级搭建iOS自动化开发环境
|
3月前
|
测试技术 虚拟化 iOS开发
iOS自动化测试方案(二):Xcode开发者工具构建WDA应用到iphone
这篇文章是iOS自动化测试方案的第二部分,详细介绍了在Xcode开发者工具中构建WebDriverAgent(WDA)应用到iPhone的全过程,包括环境准备、解决构建过程中可能遇到的错误,以及最终成功安装WDA到设备的方法。
169 0
iOS自动化测试方案(二):Xcode开发者工具构建WDA应用到iphone
|
3月前
|
测试技术 开发工具 虚拟化
iOS自动化测试方案(一):MacOS虚拟机保姆级安装Xcode教程
这篇文章提供了一份保姆级的教程,指导如何在MacOS虚拟机上安装Xcode,包括环境准备、基础软件安装以及USB扩展插件的使用,以实现iOS自动化测试方案的第一步。
83 0
iOS自动化测试方案(一):MacOS虚拟机保姆级安装Xcode教程
|
3月前
|
测试技术 Swift iOS开发
探索iOS自动化测试:使用Swift编写UI测试
【8月更文挑战第31天】在软件开发的海洋中,自动化测试是保证船只不偏离航线的灯塔。本文将带领读者启航,深入探索iOS应用的自动化UI测试。我们将通过Swift语言,点亮代码的灯塔,照亮测试的道路。文章不仅会展示如何搭建测试环境,还会提供实用的代码示例,让理论知识在实践中生根发芽。无论你是新手还是有经验的开发者,这篇文章都将是你技能提升之旅的宝贵指南。
|
3月前
|
图形学 数据安全/隐私保护 iOS开发
Unity与IOS⭐Xcode打包,上架TestFlight的完整教程
Unity与IOS⭐Xcode打包,上架TestFlight的完整教程
|
4月前
|
Android开发 iOS开发 开发者
ios应用打包、安装和上架攻略
假如是普通的证书或普通company证书只能上架才能安装(测试的话有其他安装方法,那是另外的话题),假如是企业类型的in house证书,则可以通过在线安装的方式,比如通过上传到一些分发平台,比如香蕉云编或蒲公英生成安装码扫码安装。
71 2