专栏首页每日一篇技术文章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 条评论
登录 后参与评论

相关文章

  • weex-16-image组件

    DE2586BB-4A0A-4904-AA87-EF44A8A5BC74.png

    酷走天涯
  • SceneKit - 打造全景+VR 播放框架

    1.全景模式和VR模式 2.支持滑动切换视角 3.支持捏合放大缩小 4.支持重力感应 5.包含头控功能(上一曲,下一曲,暂停和播放,以及音量键) 6....

    酷走天涯
  • OPenGL ES _ 着色器_实战2

    1.使用AVPlayer 获取视频每一帧的YUV 像素数据 2.通过CoreVideo 框架中的几个方法,将Y分量和UV 分量进行分离 3.创建着色器,对Y...

    酷走天涯
  • QT5获取文件信息

    Sindsun
  • QT5中操作QWidgetItem下的集合元素

    Sindsun
  • Java并发编程之美-双11限时五折优惠

    天猫链接:https://detail.tmall.com/item.htm?spm=a220m.1000858.1000725.61.59a73c85cVE3...

    加多
  • 【玩转腾讯云】 Nuxt.js部署到云开发静态托管

    最开始了解到Nuxt是在vue SSR下了解到,用过之后感觉真香。 可以省去路由划分的时间,Nuxt.js 会读取该目录下所有的 .vue 文件并自动生成对应的...

    XaDon
  • 【IoT迷你赛】基于TencentOS tiny 物联网案例 ——智慧生活

    本人有幸参加了TencentOS内测活动,感受到了物联网操作系统方便,因为它提供了丰富的连接云平台的模板,只需要进行二次开发,就可以很快设计出自...

    极速紫韵
  • 在IntelliJ IDEA上面进行使用svn进行版本管理

    cn華少
  • Mysql5.5——简单安装

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于Oracle旗下产品。MySQL 是最流行的关系型数据库管理系统之一,...

    江小白

扫码关注云+社区

领取腾讯云代金券