专栏首页每日一篇技术文章react-native 自动化构建过程(ipa包)

react-native 自动化构建过程(ipa包)

原理图

image.png

准备工作 1.安装xcode 2.安装cocospod 3.react-native源文件(git获取源码) 4.安装npm包管理工具 5.安装react-native-cli

npm install -g react-native-cli

步骤分解如下:

1.环境切换(CI)

react-native源文件 目录结构如下

image.png

a.根据不同的环境使用不同的配置文件(src/config/config.js)

image.png

生成发布ipa包

a.安装依赖

使用命令行 进入根目录

cd /Users/kz/Documents/myProjects/kmyd-app
npm install

等待安装完成后,执行链接任务

react-native link

进入到ios根目录

cd ios

image.png

证书目录

image.png

安装依赖

pod install

清理工程 xcodebuild clean -workspace <workspace_path> -scheme <app_scheme> -configuration <Debug Or Release> 无workspace

xcodebuild clean -workspace kmyd.xcworkspace  -scheme  kmyd -configuration Release

接下来生成archive包 xcodebuild archive -workspace 项目名称.xcworkspace -scheme 项目名称 -configuration Release -archivePath archive包存储路径 CODE_SIGN_IDENTITY=证书 PROVISIONING_PROFILE=描述文件UUID

xcodebuild archive -workspace kmyd.xcworkspace -scheme kmyd -configuration Release -archivePath archive/release.ipa 
 CODE_SIGN_IDENTITY=./certificate/release.p12 PROVISIONING_PROFILE=./certificate/release.mobileprovision

image.png

执行完命令后,此时生成一个archive包 release.ipa.xcarchive

生成ipa文件 xcodebuild -exportArchive -archivePath archive包文件路径 -exportPath 导出到指定文件目录 -exportOptionsPlist 配置文件路径

xcodebuild -exportArchive -archivePath archive/release.ipa.xcarchive  -exportPath archive/release -exportOptionsPlist kmyd/Info.plist

exportOptionsPlist kmyd/Info.plist

image.png

image.png

ios 重签名

a.准备ipa文件 和.mobileprovision (in House)

image.png

2.获取mobileprovision文件里面的信息embedded.plist

security cms -D -i release.mobileprovision > embedded.plist

image.png

3.导出entitlements.plist

/usr/libexec/PlistBuddy -x -c "Print:Entitlements" embedded.plist> entitlements.plist

image.png

4.解压ipa包

unzip kmyd.ipa

image.png

image.png

image.png

5.删除旧签名

rm -rf Payload/鲲美云店.app/_CodeSignature/

已删除

{==================动态库=====================

//如果有动态库,需要一个一个删除旧签名,并且添加新的签名

a1.删除

rm -rf Payload/鲲美云店.app/Frameworks/xxx.framework/_CodeSignature

a2.重新签名

codesign -f -s "你的证书的名称" Payload/鲲美云店.app/Frameworks/xxx.framework/

==================动态库=====================

}

6.替换配置文件

cp release.mobileprovision Payload/鲲美云店.app/embedded.mobileprovision

image.png

7.签名

image.png

codesign -f -s "iPhone Distribution: Kunchi Trading Development (Shanghai) Co., Ltd. (6DJSTWRAAQ)" --entitlements entitlements.plist Payload/鲲美云店.app

已生成新的签名包

8.打包成ipa

zip -r new_kmyd.ipa Payload/

new_kmyd自己随意生成新的ipa包的名字。

image.png

参考文献 重签名 自动构建流程 fastlane https://www.ctolib.com/topics-137029.html

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • react-native 自动化构建过程(apk包)

    准备工作 1.安装android stuido 2.react-native源文件(git获取源码) 3.安装npm包管理工具 4.安装react-na...

    酷走天涯
  • React Native热更新方案

    随着 React Native 的不断发展完善,越来越多的公司选择使用 React Native 替代 iOS/Android 进行部分业务线的开发,也有不少使...

    xiangzhihong
  • 《2016中国移动开发者大会》参会笔记

    总的来说,2016年的综合场(第一天上午)感觉讲的一般,身边的人吐槽也比较多。不过相比之下,iOS场干货就比较多了,演讲者基本都是圈内大V,包括喵神,Sunny...

    nimomeng
  • Flutter完整开发实战详解(三、 打包与填坑篇)

    作为系列文章的第三篇,继篇章一和篇章二之后,本篇将为你着重展示:Flutter开发过程的打包流程、APP包对比、细节技巧与问题处理。本篇主要描述的Flutter...

    GSYTech
  • ReactNative 原生混合开发打包ipa和apk

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 ...

    ZY_FlyWay
  • 基于React Native的移动平台研发实践分享

    本文目录: 一、React Native 已经成为了移动前端技术的趋势 二、基于React Native 进行移动平台研发过程中的一些思考 三、基于React ...

    yuanyi928
  • React Native打包

    前面写了关于React的一系列入门章:http://lib.csdn.net/xiangzhihong8/5375/chart/React%20Native ...

    xiangzhihong
  • React Native打包

    前面写了关于React的一系列入门章:http://lib.csdn.net/xiangzhihong8/5375/chart/React%20Native ...

    xiangzhihong
  • Flutter已经出世这么久了,原生开发者们是否应该有危机感?

    如果说,最早出现的会“威胁”到原生开发的跨平台方案,还不是Flutter。早在2015年Facebook推出React-Native框架时,就已经出现“reac...

    Android扫地僧

扫码关注云+社区

领取腾讯云代金券