iOS自动打发布包-备用
#!/bin/bash
# autoPublishH.sh
#
#
# Created by 刘志托 liu on 12-2-8.
# Copyright (c) 2012年 null. All rights reserved.
#以下为全局设置变量
BasePath="/Users/wangzi6hao/Developer/comProject/PAE2/branches/PAEBank12_1.7" #打包项目根代码存放目录
Version="1.7" #程序版本号
BundleId="com.pingan.PABankiPhone" #程序唯一id
IconName1="Icon.png" #程序ICON
IconName2="Icon@2x.png" #程序高清ICON
WebtrendsHttp="http://sdc.pingan.com/v1/" #网络日志内容
WebtrendsFlag="if (PA_ENVIRONMENT!=2) " #检查的配置内容
GlobalstgEntrance="#define stgEntrance 0" #检查正常入口
GlobalPA_ENVIRONMENT="#define PA_ENVIRONMENT 2" #检查生产环境
NetEntrance="#define Entrance 0" #检查正常入口
NetProType="#define proType 0" #检查正常生产环境
NetAppConfig="http://bankcdn.pingan.com.cn/assets/config/app_config.xml" #检查App config
targetStr="PAEBank" #打包目标
iosSDK="iphoneos5.0" #打包平台
DEPLOYMENTTARGET="3.0" #打包支持版本
configurationType="Distribution" #打包使用证书
ARCHSType="armv6 armv7" #打包支持内核 armv6 armv7
ZipName="PABankiPhone.app" #生成的程序App名字
codeSign="iPhone Distribution: Ping An Insurance(Group) Company Of China,LTD." #打包使用证书
#这里还可以加一个选择,当有多个证书,都是 "iPhone Distribution: Ping An Insurance(Group) Company Of China,LTD." 这个值的时候,可以指定证书的唯一ID,唯一ID可以通过在Xcode的证书配置文件里看到.可以保证证书不会弄错.
ProductName="平安口袋银行" #程序名称
LogBuildName=$BasePath/build.log #编译内容日志临时保存位置
BackupName="iPhone发布验证" #生成的程序App名字
outAppPath=$HOME/Developer/project/report/最新包/历史版本
outAppUrl="http://10.23.16.27:8888/最新包/历史版本" #通过Http来访问生成打包好的文件位置
outAppAfp="afp://10.23.16.27/report/最新包/历史版本" #通过Mac机器来访问的内容
plistName="${BasePath}/PAEBank/PAEBank-Info.plist" #要检查的plist文件名内容
WebtrendsName="${BasePath}/PAEBank/Resource/Webtrends.plist" #检查的Webtrends plist文件设置内容
WebtrendsFlagName="${BasePath}/PAEBank/公共模块/网络模块/Webtrends+extra.m" #检查Webtrends 配置文件内容
GlobalName="${BasePath}/PAEBank/公共模块/Global.h" #检查全局配置文件
NetControllerHName="${BasePath}/PAEBank/公共模块/网络模块/NetController.h" #检查NetController.h 网络模块内容
NetControllerMName="${BasePath}/PAEBank/公共模块/网络模块/NetController.m" #检查NetController.m 网络模块内容
#当传入的第一个参数不为0的时候,退出程序
function errorExit(){
if [ $1 -ne 0 ];then
echo $2
echo "XXXX ERROR XXXX ERROR XXXX ERROR XXXX ERROR XXXX XXXX ERROR XXXX "
exit 1
fi
}
cd $BasePath
errorExit $? "!!!错误!!!找不到目录:"$BasePath
echo "进入文件夹:"`pwd`
ITEMLINENUMBER="0"
checkItem="版本号"
((ITEMLINENUMBER ++))
echo "${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $Version
lineNumber=`grep -n "<key>CFBundleVersion<\/key>" $plistName | awk -F: '{print $1}'` #获取版本号KEY在第几行
((lineNumber ++)) #获取下版本KEY对应的Value所有行
sed -n ''${lineNumber}'p' $plistName | grep "<string>${Version}<\/string>" 1>/dev/null #检查值所在行,是否存在
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="程序显示名称"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $ProductName
lineNumber=`grep -n "<key>CFBundleDisplayName<\/key>" $plistName | awk -F: '{print $1}'` #获取版本号KEY在第几行
((lineNumber ++)) #获取下版本KEY对应的Value所有行
sed -n ''${lineNumber}'p' $plistName | grep "<string>${ProductName}<\/string>" 1>/dev/null #检查值所在行,是否存在
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="程序ID"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $BundleId
lineNumber=`grep -n "<key>CFBundleIdentifier<\/key>" $plistName | awk -F: '{print $1}'` #获取版本号KEY在第几行
((lineNumber ++)) #获取下版本KEY对应的Value所有行
sed -n ''${lineNumber}'p' $plistName | grep "<string>${BundleId}<\/string>" 1>/dev/null #检查值所在行,是否存在
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="图标是否具有光晕效果"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo "YES"
lineNumber=`grep -n "<key>UIPrerenderedIcon<\/key>" $plistName | awk -F: '{print $1}'` #获取版本号KEY在第几行
((lineNumber ++)) #获取下版本KEY对应的Value所有行
sed -n ''${lineNumber}'p' $plistName | grep "<true\/>" 1>/dev/null #检查值所在行,是否存在
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="程序图标1"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $IconName1
lineNumber=`grep -n "<key>CFBundleIconFiles<\/key>" $plistName | awk -F: '{print $1}'` #获取版本号KEY在第几行
((lineNumber +=2)) #获取下版本KEY对应的Value所有行
sed -n ''${lineNumber}'p' $plistName | grep "<string>${IconName1}<\/string>" 1>/dev/null #检查值所在行,是否存在
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="程序图标2"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $IconName2
((lineNumber ++)) #获取下版本KEY对应的Value所有行
sed -n ''${lineNumber}'p' $plistName | grep "<string>${IconName2}<\/string>" 1>/dev/null #检查值所在行,是否存在
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="程序图标资源1"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $IconName1
if [ -f "${BasePath}/PAEBank/Resource/图片/$IconName1" ];then
echo "E结束${checkItem}检查,${checkItem}存在."
else
errorExit 1 "!!!错误!!!,文件夹中找不到对应的${checkItem}"
fi
checkItem="程序图标资源2"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $IconName2
if [ -f "${BasePath}/PAEBank/Resource/图片/$IconName2" ];then
echo "E结束${checkItem}检查,${checkItem}存在."
else
errorExit 1 "!!!错误!!!,文件夹中找不到对应的${checkItem}"
fi
checkItem="Webtrends地址"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $WebtrendsHttp
webUrl=`strings $WebtrendsName |grep "$WebtrendsHttp"` #检查值所在行,是否存在
if [ ! "${webUrl}" == "${WebtrendsHttp}" ];then
errorExit 1 "!!!错误!!!,找不到对应的${WebtrendsHttp}"
fi
echo "E结束${checkItem}检查,正确."
checkItem="Webtrends是否激活"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $WebtrendsFlag
grep "$WebtrendsFlag" $WebtrendsFlagName 1>/dev/null
errorExit $? "!!!错误!!!,找不到对应的${WebtrendsFlag}"
echo "E结束${checkItem}检查,正确."
checkItem="全局配置 正常入口 "
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $GlobalstgEntrance
grep "$GlobalstgEntrance\>" $GlobalName
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="全局配置 生产发布环境 "
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $GlobalPA_ENVIRONMENT
grep "$GlobalPA_ENVIRONMENT\>" $GlobalName
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="网络配置 正常入口 "
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $NetEntrance
grep "$NetEntrance\>" $NetControllerHName
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="网络配置 正常生产环境 "
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $NetProType
grep "$NetProType\>" $NetControllerHName
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="网络配置 App config "
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始检查:${checkItem}========================="
echo $NetAppConfig
grep "$NetAppConfig\>" $NetControllerMName
errorExit $? "!!!错误!!!,找不到对应的${checkItem}"
echo "E结束${checkItem}检查,正确."
checkItem="打包Base SDK"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S打包信息:${checkItem}========================="
echo $iosSDK
checkItem="打包iOS Deployment Target"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S打包信息:${checkItem}========================="
echo $DEPLOYMENTTARGET
checkItem="打包Build Configuration"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S打包信息:${checkItem}========================="
echo $configurationType
checkItem="打包Architectures"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S打包信息:${checkItem}========================="
echo $ARCHSType
checkItem="清除编译文件"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始:${checkItem}========================="
xcodebuild clean -configuration $configurationType -sdk $iosSDK -target $targetStr IPHONEOS_DEPLOYMENT_TARGET=$DEPLOYMENTTARGET GCC_VERSION="com.apple.compilers.llvm.clang.1_0" ARCHS="$ARCHSType" 1>/dev/null
errorExit $? "!!!错误!!!${checkItem}"
echo "E结束${checkItem},正确."
checkItem="编译发布包文件"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始:${checkItem}========================="
xcodebuild -configuration $configurationType -sdk $iosSDK -target $targetStr IPHONEOS_DEPLOYMENT_TARGET=$DEPLOYMENTTARGET GCC_VERSION="com.apple.compilers.llvm.clang.1_0" ARCHS="$ARCHSType" CODE_SIGN_IDENTITY="$codeSign">$LogBuildName
errorFlag=$?
checkItem="获取编译中警告和错误日志内容"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始:${checkItem}========================="
grep -E " warning| error|SUCCEEDED" $LogBuildName
errorExit $? "!!!错误!!!${checkItem}"
echo "E结束${checkItem},正确."
if [ $errorFlag -ne 0 ];then
errorExit $errorFlag "!!!错误!!!"
fi
checkItem="获取编译中打包证书"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始:${checkItem}========================="
grep "${codeSign}" $LogBuildName
errorExit $? "!!!错误!!!${checkItem}"
codeSignCount=`grep -c "${codeSign}" $LogBuildName` #获取有几个证书编号
if [ $codeSignCount -ne 2 ];then #如果证书显示数量没有2个,出错
errorExit $? "!!!错误!!!${checkItem}"
fi
echo "E结束${checkItem},正确."
checkItem="复制 app和dsym 文件备份"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始:${checkItem}========================="
VersionPath=$outAppPath/$Version #指定备份路径下,生成版本号文件夹,来管理当前对应版本号的内容
if [ ! -d "$VersionPath" ]; then
mkdir -p "$VersionPath"
errorExit $? "!!!错误!!!${BackupPath} 生成错误!"
echo "创建文件夹:$Version"
fi
echo "删除之前生成的文件内容"
BackupPath=$VersionPath/$BackupName #指定备份路径下,生成不同设备的文件夹
rm -rf "$BackupPath" #删除之前生成编译包,每个版本只可能有一个发布包
errorExit $? "!!!错误!!!${BackupName}删除出错"
mkdir -p "$BackupPath" #再次生成保存编译包文件夹
errorExit $? "!!!错误!!!${BackupPath} 生成错误!"
mv $LogBuildName $BackupPath
errorExit $? "!!!错误!!!移动打包日志到:${BackupPath} 错误!"
cp -rf build/$configurationType-iphoneos/* $BackupPath #复制 app和dsym 文件备份
errorExit $? "!!!错误!!!${checkItem}"
echo "E结束${checkItem},正确."
checkItem="压缩一个app的zip文件,用来上传到appstore用"
((ITEMLINENUMBER ++))
echo -e "\n\n${ITEMLINENUMBER}.=========================S开始:${checkItem}========================="
cd $BackupPath #进入到版本号文件内容
zip -r "${ZipName}.zip" $ZipName 1>/dev/null
errorExit $? "!!!错误!!!${checkItem}"
echo "E结束${checkItem},正确."
echo -e "\n\n*********************************************************"
echo -e "打包内容可以通过以下网址访问到:"
echo -e "${outAppUrl}/${Version}/${BackupName}"
echo -e "\n或者通过mac下的'Finder'->'前往'->'链接服务器'->'${outAppAfp}/${Version}/${BackupName}'->使用来宾客户登录即可"
iOS自动打发布包-备用的更多相关文章
- ios自动打包-fastlane 安装、使用、更新和卸载
ios自动打包使用fastlane 1.首先安装xcode 首先检查是否已经安装 Xcode 命令行工具,fastlane 使用 xcodebuild 命令进行打包,运行 xcode-select - ...
- 40、IOS自动打包-Python脚本
第一种:基于编译的打包 编译工程--找到.app文件--新建Payload文件夹--拷贝.app到Payload文件夹--压缩成zip--更改后缀名为ipa--完成! 第二种(有问题,暂时不需要看) ...
- 设置iOS项目BuildVersion自动增加-备用
一.概念阐述:Build与Version的区别 在iOS中有两种“版本号”,也就是所谓的version号与build号,如下图所示: 我们用最简洁的语言来区分这两个版本号的区别以及用途如下: Vers ...
- iOS知识点全梳理-备用
感谢大神分享 文/Jack_lin(简书作者)原文链接:http://www.jianshu.com/p/5d2163640e26著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 序言 ...
- iOS自动更新如何实现
APP检测更新可以使用两种方法.第一种是和安卓等系统一样,获取自己服务器的APP版本号与已安装的APP版本号比较:第二种是根据已发布到app store上的应用版本号与已安装的APP版本号比较更新.第 ...
- ios自动滚动图片功能源码
源码AdScrollerView,一个已经封装好的UIScrollView的子类,可以自动滚动图片以及对应的描述语,类似淘宝app首页的广告滚动效果.滚动图片数量不限,并且显示pageControl. ...
- iOS 后台运行实现 --备用
文一 我从苹果文档中得知,一般的应用在进入后台的时候可以获取一定时间来运行相关任务,也就是说可以在后台运行一小段时间. 还有三种类型的可以运行在后以,1.音乐2.location 3.voip 文二 ...
- ios coredata 老代码备用参考
iPhone OS在2009年6月份推出3.0版本SDK,其中一个特性是引入了Mac SDK中的core data.是一种ORM(Object Relationships Mapping)解决方案,类 ...
- MAC上搭建Jenkins + Android + IOS自动开发部署环境
因为MAC是大小写不敏感的操作系统,很多Linux命令不支持,所以首先要创建大小写敏感的操作系统. 设置静态IP 打开"System Preferences..." 点击" ...
随机推荐
- 求四百万以内Fibonacci(number)数列偶数结果的总和
又对啦...开心~~~~ 只是代码可能不符合PEP标准什么的... Each new term in the Fibonacci sequence is generated by adding the ...
- Keil C51 中的函数指针和再入函数
函数指针是C语言中几个难点之一.由于8051的C编译器的独特要求,函数指针和再入函数有更多的挑战需要克服.主要由于函数变量的传递.典型的(绝大部分8051芯片)函数变量通过堆栈的入栈和出栈命令来传递. ...
- Mono Compatibility
The easiest way to describe what Mono currently supports is:Everything in .NET 4.5 except WPF, WWF, ...
- 【HDOJ】4504 威威猫系列故事——篮球梦
水题. #include <cstdio> #include <cstdlib> #include <cstring> #define MAXN 25 ]; voi ...
- 设计模式(十五):Iterator迭代器模式 -- 行为型模式
1.概述 类中的面向对象编程封装应用逻辑.类,就是实例化的对象,每个单独的对象都有一个特定的身份和状态.单独的对象是一种组织代码的有用方法,但通常你会处理一组对象或者集合. 集合不一定是均一的.图形用 ...
- 【转】24. android dialog ——ProgressDialog 进度条对话框详解
原文网址:http://blog.csdn.net/jamesliulyc/article/details/6375598 首先在onCreateDialog方法里创建一个ProgressDialog ...
- 如何消除word中的回车符号
打开文字编辑页面,在菜单栏上选择工具-选项-视图-格式标志中的“段落标志”复选框前面的“√”去掉即可. 附件:
- [转]10款 Web 开发常备工具
文章地址:https://my.oschina.net/u/2903254/blog/798135 工欲善其事,必先利其器.如今 Web 开发标准越来越高,Web 开发者也在不断寻找途径提升自己的技能 ...
- Codeforces Round #300 F - A Heap of Heaps (树状数组 OR 差分)
F. A Heap of Heaps time limit per test 3 seconds memory limit per test 512 megabytes input standard ...
- Stooge排序
又叫臭皮匠排序... 在<算法导论>作为反例出现的漂亮但极其低效的排序算法. 基本思路是:只要数组长度大于3,先将头与尾排序,然后递归调用排序前三分之二,再递归调用排序后三分之二,最后再递 ...