摘要

  随着苹果手持设备用户的不断增加,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 xcodebuild[-project
2 ][-activetarget][-alltargets][-target]...[-parallelizeTargets][-activeconfiguration][-configuration][-sdk
|][=]...[]...
3 xcodebuild[-version[-sdk
|]]
4 xcodebuild[-showsdks]
5 xcodebuild[-find ][-sdk
|]
6 xcodebuild[-list]

也可以在终端输入:xcodebuild –help 或 –h查看具体的选项

显示xcodebuildversion:xcodebuild –version

显示当前系统安装的sdk:xcodebuild –showsdks

显示当前目录下project Information:xcodebuild –list

需要注意的是:执行以上命令时必须把位置定位在ios项目文件的根目录下 否则会提示找不相关命令的。

2、xcrun 介绍:

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

具体用法如下:

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

其中:-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 脚本代码:

01 #!/bin/sh
02  
03 xcodebuild
clean -configuration Distribution      //clean项目
04  
05 distDir="/Users/xxxx/dist"
06 releaseDir="build/Distribution-iphoneos"
07 version="1_0_0"
08 rm -rdf "$distDir"
09 mkdir "$distDir"
10 for line in $(cat data.dat)       
//读取所有渠道号data.dat文件
11 do
12 ipafilename=`echo $line|cut -f1
-d
':'`
//渠道名
13 sourceid=`echo $line|cut -f2
-d
':'`   
//渠道号
14 echo "ipafilename=$ipaname"
15 echo "sourceid=$sourceid"
16 targetName="youtargename"   //项目名称(xcode左边列表中显示的项目名称)
17 echo "sourceid=$sourceid"
18 echo "ipafilename=$ipafilename"
19 echo "$sourceid" >
sourceid.dat
20 echo "sourceid.dat:
"
21 cat sourceid.dat
22 rm -rdf "$releaseDir"
23  
24 ipapath="${distDir}/${targetName}_${version}_from_${sourceid}.ipa"
25  
26 echo "***开始build
app文件***"
27 xcodebuild
-target 
"$targetName" -configuration
Distribution  -sdk iphoneos build
28 appfile="${releaseDir}/${targetName}.app"
29 if [
$sourceid == 
"appstore" ]
30 then
31 cd $releaseDir
32 zip
-r 
"${targetName}_${ipafilename}_${version}.zip" "${targetName}.app"
33 mv "${targetName}_${ipafilename}.zip" $distDir
2> /dev/null
34 cd ../..
35 else
36 echo "***开始打ipa渠道包****"
37 /usr/bin/xcrun
-sdk iphoneos PackageApplication -
v "$appfile" -o "$ipapath" --sign"iPhone
Distribution:xxxxxx"
38 fi
39 done

注:以上的data.dat文件为存放渠道号列表的文件 其格式为:3g:1001b 即 (渠道名:渠道号) sourceid.dat 为项目文件中存放渠道号的文件(内容只有一个渠道号)。当然了上面脚本只是说明了下如何利用xcodebuild 和 xcrun 进行打包 以及自动打包的一个逻辑,shell脚本好的同学可以自由发挥哈。。。

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

01 #!/bin/sh
02 sourceipaname="母包名.ipa"
03 appname=”app文件名.app” 
//加压后Pauload目录项.app文件名需要根据自己的项目修改
04 distDir="/Users/lxxx/Qa"   //打包后文件存储目录
05 version="1.0.0"
06 rm -rdf "$distDir
"
07 mkdir "$distDir" unzip
$sourceipaname     //解压母包文件
08 for line in $(cat data.dat)  
//读取渠道号文件并进行循环
09  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="ipa包名"
15     echo "sourceid=$sourceid"
16     echo "ipafilename=$ipafilename"
17     cd Payload
18     cd $appname
19     echo "replace
sourceid.dat before: "
20     cat sourceid.dat
21     echo "$sourceid" >
sourceid.dat
22     echo "replace
sourceid.dat after: "
23  cat sourceid.dat
24  if [
$sourceid == 
"appstroe" ]
25 then
26  cd ..
27 zip
-r 
"${targetName}_${version}_from_${sourceid}.zip" $appname
//appstore二进制文件
28  
29     mv "${targetName}_${version}_from_${sourceid}.zip" $distDir
30     cd ..
31     else
32     cd ../..
33     zip
-r 
"${targetName}_${version}_from_${sourceid}.ipa" Payload  
//打成其他渠道的包
34 mv "${targetName}_${version}_from_${sourceid}.ipa" $distDir
35     fi
36  done rm -rdf
Payload

注:以上data.dat也是用来存储所有渠道号的,sourceipaname就是通过qa验证的母包,appname为ipa包加压后Payload 目录下的app文件名并且以上所有文件必须与脚本文件保持在同一目录下以及在mac环境中执行。

IOS自动化打包介绍的更多相关文章

  1. Mac Jenkins+fastlane 简单几步实现iOS自动化打包发布 + jenkins节点设置

    最近在使用jenkins 实现ios自动化打包发布蒲公英过程实践遇到了一些坑,特意记录下来方便有需要的人. 进入正题: 一.安装Jenkins 1.Mac上安装Jenkins 遇到到坑 因为 Jenk ...

  2. Jenkins+ Xcode+ 蒲公英 实现IOS自动化打包和分发

    Jenkins+ Xcode+ 蒲公英 实现IOS自动化打包和分发 直接入正题: Screen Shot 2015-09-18 at 16.56.20.png Mac上安装Jekins jekins下 ...

  3. iOS自动化打包上传的踩坑记

    http://www.cocoachina.com/ios/20160624/16811.html 很久以前就看了很多关于iOS自动打包ipa的文章, 看着感觉很简单, 但是因为一直没有AppleDe ...

  4. iOS自动化打包 Jenkins+Gitlab+Fastlane+蒲公英+钉钉

    前言 这两天花时间整理一下自动化打包的整套流程,现在iOS端的整套流程是没有问题了,这个过程中踩得坑也的确是特别多,所以这周末把整个流程整理一下,总结出来这篇文章,希望能对有需要的小伙伴有点点帮助. ...

  5. iOS自动化打包发布(fastlane)

    一.FastLane介绍 1.1 FastLane是什么? FastLane是一种配置iOS和Android自动化Beta部署和发布的最简单的方法之一.它可以简化一些乏味.单调.重复的工作,像截图.代 ...

  6. iOS 自动化打包

    理想的情况:不打开工程的情况下,直接双击就能打包出一个IPA文件,这样就可以让测试直接使用 itools 进行安装. 分如下两种情况: 1)不依赖cocoapod  管理项目的自动化. 如果没有一个简 ...

  7. iOS 自动化打包发布(Fastlane+ Jenkins+蒲公英)

    安装 Xcode 命令行工具:xcode-select --install 安装 fastlane:sudo gem install fastlane --verbose 安装成功后查看版本:fast ...

  8. 一个IOS自动化打包的脚本

    网上找了一个脚本,在其中进行了修改,只需要一条命令就可以了 支持自动导入配置文件 支持自动安装p12证书 支持自动修改版本号和build版本号 支持自动修改app显示名称 支持自动修改bundle i ...

  9. xcodebuild 自动化打包

    altool 文档 使用xcode自带的xcodebuild 命令通过脚本进行打包 打包->导出ipa, 两行关键的脚本代码 1.Archive xcodebuild archive -arch ...

随机推荐

  1. js实现复制|剪切指定内容到粘贴板--clipboard

    这是著名开源项目 clipboard.js 的 README.md,里面讲解的更加详细,有兴趣的同学可以了解一下.项目地址:https://github.com/zenorocha/clipboard ...

  2. hive建模方法

    转自:https://www.jianshu.com/p/8378b80e4b21 概述数据仓库这个概念是由 Bill Inmon 所提出的,其功能是将组织通过联机事务处理(OLTP)所积累的大量的资 ...

  3. readUTF()和writeUTF()

    readUTF()和writeUTF() 这是dataOutputStream 的方法~~使用utf-8编码 其实就是从unicode变过来的,utf8编码把unicode的ASCII编码变成1个字节 ...

  4. [Go语言]cgo用法演示

        经历了数十年发展的C语言,各种各样的现成的库已经非常丰富.通过cgo,可以在Go语言中使用C语言代码,充分利用好现有的“轮子”. 本文所有代码,在下述环境中调试通过: Windows 8.1 ...

  5. 使用wordpress搭建的网站如何去掉域名中的wordpess

    我们搭建好的网站当以文件夹的形式把wordpress程序放在空间的根目录时,访问的时候要加上文件夹名,访问地址就是:http://www.xxx.com/wordpress,直接用域名是无法访问,解决 ...

  6. 戏说 .NET GDI+系列学习教程(三、Graphics类的应用_自定义控件--主要用于画面拖拽效果)

    如题,需求:在某个图片上用户可以手动指定位置. 如下: 中心思想:仿照Visual Studio工具中的控件的做法 如何仿照呢? 1.自定义的控件类继承System.Windows.Forms.Con ...

  7. Haskell语法

    http://www.ibm.com/developerworks/cn/java/j-cb07186.html 1. 构造符号 : 比如: 1:2:3:[] 而常用的 [1,2,3] 是一种语法糖( ...

  8. 剑指offer——51丑数

    题目描述 把只包含质因子2.3和5的数称作丑数(Ugly Number).例如6.8都是丑数,但14不是,因为它包含质因子7. 习惯上我们把1当做是第一个丑数.求按从小到大的顺序的第N个丑数.   / ...

  9. 51-Ubuntu-打包压缩-1-打包压缩简介

    打包压缩是日常工作中备份文件的一种方式 在不同操作系统中,常用的打包压缩方式是不同的 Windows 常用 rar Mac 常用 zip Linux 常用 tar.gz

  10. Handler Looper源码解析(Android消息传递机制)

    Android的Handler类应该是常用到的,多用于线程间的通信,以及子线程发送消息通知UI线程刷新View等等.这里我主要总结下我对整个消息传递机制,包括Handler,Looper,Messag ...