XCode9制作一键打包脚本

作者: 程序H | 来源:发表于2017-11-17 11:36 被阅读628次

    做iOS开发,打包APP是比较频繁的事情,每次都需要手动去配置一堆东西确实麻烦。所以要是可以简单执行一个脚本就完成打包的各种配置,那就轻松了!
    于是我再网上学习实现自动化打包的方法,但是好多都是老版本。所以我打算参考别人教程,然后自己也研究研究,再把研究的结果和大家分享一下。
    参考文章:
    http://www.jianshu.com/p/97c97c2ec1ca
    http://www.jianshu.com/p/3f43370437d2
    http://blog.csdn.net/potato512/article/details/52172107
    http://blog.csdn.net/itiapp_home/article/details/70241011


    Begin to do

    小牛试刀

    其实当Xcode点击build或者运行comand+R之后,Xcode执行的命令是xcodebuild这条命令。
    打开终端,cd到你的工程位置,然后试一下xcodebuild、xcrun命令,看看自己电脑是否安装了xcodebuild及xcrun。

    # xcodebuild
    kuangzihandeMacBook-Pro:YuanKezi kuangzihan$ xcodebuild -version  
    Xcode 9.1
    Build version 9B55
    
    # xcrun
    kuangzihandeMacBook-Pro:YuanKezi kuangzihan$ xcrun --version
    xcrun version 35.
    

    xcodebuild命令是苹果官方推出的打包命令,可以在终端输入xcodebuild -help查看,也可以看官方文档

    背景知识

    在8.3之前推荐使用xcodebuild + xcrunPackageApplication的方式打包,笔者在学习过程中也使用过,但是执行命令行时报错xcrun: error: unable to find utility "PackageApplication", not a developer tool or in PATH,提示很明显在路径中找不到PackageApplication文件,虽然网上也有提供下载PackageApplication方式的解决方法,但笔者在Xocde9下尝试无效。
    于是笔者使用了官方推荐的arhive+exportArchive的方式来打包。本文也主要讲解如何通过arhive+exportArchive方式打包。

    命令行

    生成Archive包

    首先需要在xcode项目配置好证书及描述文件,然后打开终端cd到项目目录,执行编辑并清理命令。

    xcodebuild archive 
               -workspace 项目名称.xcworkspace (非cocoapods项目使用 -project 项目名称.xcodeproj)
               -scheme 项目名称 
               -configuration 构建版本(Debug or Release) 
               -archivePath archive包存储路径  
               clean archive  清理
    
    • -workspace or -project
      此处有区别,如果非cocoapods项目使用-project 项目名称.xcodeproj,cocoapods项目使用-workspace 项目名称.xcworkspace
    • -scheme 可以通过xcodebuild -list获取;
    • -configuration 一些参数,也可以通过xcodebuild -list获取,一般使用DebugorRelease
    • -archivePath 生成archivePath的路径,一般放项目目录下并且自定义一个文件夹名称,例如archive/test.xcarchive
    • clean archive 编译之前清理;
    生成ipa文件

    上文已经提到PackageApplication已经不推荐,本文通过arhive+exportArchive来实现打包。

    xcodebuild -exportArchive -archivePath archive文件的地址.xcarchive
                              -exportPath 导出ipa文件路径 
                              -exportOptionsPlist exportOptionsPlist文件路径  
                              -allowProvisioningUpdates 允许配置更新
    
    • -archivePath 此路径为生成Archive包步骤中生成的archive路径;
    • -exportPath 设置导出ipa文件路径;
    • -exportOptionsPlist
      此处需要详细说明下,笔者在调研过程中也卡在此处,此plist并非项目中info.plist文件路径,是需要新建一个plist文件,格式是如下:
    ExportOptions.png
    ** ExportOptions.plist文件参数说明 ** 
    compileBitcode:不上架App Store,Xcode是否启用Bitcode重新编译,默认为YES。 
    method:归档类型,包括app-store、ad-hoc、package、enterprise、development以及developer-id。 
    uploadBitcode:上线App Store是否开启Bitcode,默认为YES。 
    uploadSymbols:上线App Store,是否开启符号序列化,这是与查crash相关的,默认为YES。
    

    特别说明下,在Xcode9之前是不需要ExportOptions.plist ,在Xcode9之后必须加入 ExportOptions.plist
    最后此处指向创建plist文件的路径即可;

    • allowProvisioningUpdates 允许配置更新;

    生成Shell脚本介绍

    上面所述均是通过命令行的方式实现打包,但执行起来还需要输入命令行,还是不太方便,下面介绍通过生成一个Shell脚本来来实现一键打包。(详细的Sell命令,有兴趣的同学可以在Shell教程中详细学习)
    首先打开终端输入如下命令:

    touch test
    
    在user目录可看到生成的test文本文件

    打开文件,输入如下:

    #!/bin/sh  
    echo "Hello Shell"
    

    然后执行:

    chmod +x test
    

    执行成功后查看之前test文本文件,变成了Unix可执行文件(即生成了一个简单脚本),双击脚本即可查看打印的Hello Shell,如下:

    kuangzihandeMacBook-Pro:~ kuangzihan$ /Users/kuangzihan/test ; exit;
    Hello Shell
    logout
    Saving session...
    ...copying shared history...
    ...saving history...truncating history files...
    ...completed.
    
    [进程已完成]
    

    一键打包Shell脚本

    以下是我自动打包的主要代码:

    #! /bin/bash
    # created by Ficow Shen
    
    #工程绝对路径
    project_path=$(pwd)/TestProjects
    
    #工程名称
    project_name=TestProjects
    
    #打包模式 Debug/Release
    development_mode=Debug
    
    #scheme名
    scheme_name=TestProjects
    
    #archive文件夹名称
    archive_path=archive
    
    #plist文件所在路径
    exportOptionsPlistPath=$(pwd)/iOS/IPA.plist
    
    #导出.ipa文件所在路径
    exportFilePath=$(pwd)/Desktop/${scheme_name}_IPA
    
    
    
    echo '*** 正在 编译工程 For '${development_mode}
    xcodebuild \
    archive \
    -workspace ${project_path}/${project_name}.xcworkspace \
    -scheme ${scheme_name} \
    -configuration ${development_mode} \
    -archivePath ${project_path}/${archive_path}/${project_name}.xcarchive \
    clean archive \
    -quiet || exit
    echo '*** 编译完成 ***'
    
    echo '*** 正在 打包 ***'
    xcodebuild \
    -exportArchive \
    -archivePath ${project_path}/${archive_path}/${project_name}.xcarchive \
    -exportPath ${exportFilePath} \
    -exportOptionsPlist ${exportOptionsPlistPath} \
    -allowProvisioningUpdates \
    -quiet || exit
    
    if [ -e $exportFilePath/$scheme_name.ipa ]; then
        echo "*** .ipa文件已导出 ***"
        open $exportFilePath
    else
        echo "*** 创建.ipa文件失败 ***"
    fi
    echo '*** 打包完成 ***'
    

    修改如下几点即可使用此脚本实现一键打包:

    1. project_path $(pwd)为电脑的用户目录,此处填写项目根目录即可;
    2. project_name 此处修改为项目名称;
    3. scheme_name 此处同样可以修改为项目名称;
    4. exportOptionsPlist 此处需要填写上文提到的exportOptionsPlist.plist文件所在目录;
    5. exportFilePath 导出ipa文件路径,默认设置桌面;

    相关文章

      网友评论

      • 午马丶:1. 你好创建的这个文件ExportOptions.plist是必须要放在工程里吗? 还是放在桌面或者工程里都可以。2. 这个文件中的provisionProfile里放什么东西呀,是要把描述文件的名字放进去吗? 希望不吝赐教谢谢。
        程序H:抱歉,一直没有登录简书,才看到。
        程序H:provisioningProfiles中,key是bundleid,value是对应的provisioningProfile的名称或ID
        程序H:plist放哪里都可以,-exportOptionsPlist设置plist文件存放目录就可以。
      • coder_那一抹刚吹过的风:您好,你这个写的稍微有点走心啊。plist的参数说明不一致啊
        程序H:感谢提醒,已做修改。
      • Jackie虎:https://github.com/jackiehu/IPAAutoBuild 我写的这个,不用自己写路径什么的,直接脚本自己识别,放到工程目录下双击就可以了

      本文标题:XCode9制作一键打包脚本

      本文链接:https://www.haomeiwen.com/subject/ibydvxtx.html