当前位置: 首页 > news >正文

[无需 Mac] 使用 GitHub Actions 构建 iOS 应用

  • [无需 Mac] 使用 GitHub Actions 构建 iOS 应用
    • 介绍
    • 1.准备存储库
    • 2.配置 GitHub Actions
    • 3. 设置密钥密码
      • ExportOptions.plist创建
      • 创建 App Store Connect API 密钥
        • 如何进行Base64编码
      • 设置应用密码
    • 4.执行
    • 当出错时

推荐超级课程:

  • 本地离线DeepSeek AI方案部署实战教程【完全版】
  • Docker快速入门到精通
  • Kubernetes入门到大师通关课
  • AWS云服务快速入门实战

介绍

GitHub Actions 是 GitHub 上用于自动化工作流程的功能。
在本文中,我们将向您展示如何在没有 Mac 的情况下使用 GitHub Actions 构建 iOS 应用。

要上传到 App Store Connect,您需要注册 Apple 开发者计划。

1.准备存储库

首先,准备好你的 iOS 应用仓库。
本文假设你的应用目录结构如下:

.
├── .github
│   └── workflows
│       └── build.yml
├── MyApp
│   ├── MyApp.xcodeproj
│   └── ...
└── ...

2.配置 GitHub Actions

在存储库根目录中.github/workflows/build.yml创建一个目录,其中包含以下内容:

构建文件

name: Buildon:pushjobs:          build:name: Buildruns-on: macos-lateststeps:- name: Checkoutuses: actions/checkout@v4- name: Archive Projectrun: |                        xcodebuild archive -project MyApp/MyApp.xcodeproj \-scheme MainApp \-sdk iphoneos \-configuration Release \-archivePath MainApp.xcarchive \CODE_SIGNING_ALLOWED=NO- name: Create ExportOptions.plistrun: |echo '${{ secrets.EXPORT_OPTIONS }}' > ExportOptions.plist- name: Create Private Keyrun: |mkdir private_keysecho -n '${{ secrets.APPLE_API_KEY_BASE64 }}' | base64 --decode > ./private_keys/AuthKey_${{ secrets.APPLE_API_ISSUER_ID }}.p8- name: Export IPArun: |   xcodebuild -exportArchive \-archivePath MainApp.xcarchive \-exportOptionsPlist ExportOptions.plist \-exportPath app.ipa \-allowProvisioningUpdates \-authenticationKeyPath `pwd`/private_keys/AuthKey_${{ secrets.APPLE_API_ISSUER_ID }}.p8 \-authenticationKeyID ${{ secrets.APPLE_API_KEY_ID }} \-authenticationKeyIssuerID ${{ secrets.APPLE_API_ISSUER_ID }}- name: Upload IPA to App Store Connectrun: |xcrun altool --upload-app -f app.ipa/MainApp.ipa \-u ${{ secrets.APPLE_ID }} \-p ${{ secrets.APP_SPECIFIC_PASSWORD }} \--type ios

在此设置中,xcodebuild我们使用命令来构建我们的 iOS 应用程序,并xcrun altool使用命令将其上传到 App Store Connect。

要点如下:

  • Xcode 项目路径MyApp/MyApp.xcodeproj和方案名称MainApp均为默认设置。请根据需要进行更改。
  • 在您的 Xcode 项目中启用自动签名。
  • xcodebuild buildxcodebuild archiveCODE_SIGNING_ALLOWED=NO您指定使签名无效时。
  • 私钥路径在内部隐式引用,不应更改。
  • -allowProvisioningUpdates因为您指定了,所以您不需要配置文件,
    并且您不需要每年更新配置文件。

3. 设置密钥密码

在 GitHub 存储库设置屏幕上,在“存储库机密”中设置以下机密。
有关详细的设置说明,请参阅GitHub 文档。

  • EXPORT_OPTIONS``ExportOptions.plist内容:
  • APPLE_API_KEY_BASE64:App Store Connect API 密钥的 Base64 编码内容
  • APPLE_API_ISSUER_ID:App Store Connect API 发行者 ID
  • APPLE_API_KEY_ID:App Store Connect API 密钥 ID
  • APPLE_ID:Apple ID
  • APP_SPECIFIC_PASSWORD:Apple ID 应用密码

ExportOptions.plist创建

EXPORT_OPTIONS以下是它的内容。您可以从
YOUR_TEAM_IDApple Developer Program Membership中查看。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict><key>method</key><string>app-store</string><key>teamID</key><string>YOUR_TEAM_ID</string>
</dict>
</plist>

创建 App Store Connect API 密钥

您可以通过 App Store Connect API 创建App Store Connect API密钥。
您可以使用任意名称,但Admin需要拥有 App Store Connect API 的访问权限。
有关如何颁发密钥的详细说明,请参阅Apple 的文档。

APPLE_API_KEY_BASE64是密钥内容。
请注意,该内容只能下载一次。请对其
进行Base64编码并设置为机密。

如何进行Base64编码

您可以使用以下命令将其以 Base64 进行编码:

Windows(PowerShell)

[Convert]::ToBase64String([System.IO.File]::ReadAllBytes("AuthKey_YOUR_ISSUER_ID.p8"))

Linux / macOS

base64 -i AuthKey_YOUR_ISSUER_ID.p8

APPLE_API_ISSUER_ID是密钥的颁发者 ID,
所有密钥的颁发者 ID 都是相同的。

APPLE_API_KEY_ID是您的密钥 ID。它也是
下载的密钥文件名AuthKey_后面的字符串。

设置应用密码

APPLE_ID是您的 Apple ID(电子邮件地址)。
请设置您注册 Apple Developer Program 时使用的 Apple ID。

APP_SPECIFIC_PASSWORD是根据您 Apple ID 的应用专用密码创建的。
有关如何设置的更多信息,请参阅Apple 的文档。

4.执行

您现在可以出发了。

当您推送到 GitHub 时,GitHub Actions 将自动执行。
如果构建成功,该应用将上传至 App Store Connect。
您可以在 App Store Connect 中创建内部测试版本,无需审核。
不妨在您的 iPhone 上测试一下!

当出错时

如果您的工作流程失败,请检查以下内容:

  • Xcode 项目路径和方案名称是否正确?
    xcodebuild -list -project MyApp/MyApp.xcodeproj您可以检查方案名称。
  • 您的 Xcode 项目中是否启用了自动签名?
  • 密钥密码都设定好了吗?
  • APPLE_API_KEY_BASE64它是Base64编码的吗?
  • App Store Connect API 密钥权限是否正确?
  • 您可以检查MainApp.ipa目录中是否已创建app.ipa 。
    根据项目的不同,它的名称可能会有所不同。
    ls -l app.ipa

>

http://www.lryc.cn/news/612625.html

相关文章:

  • 嵌入式硬件学习(十一)—— platform驱动框架
  • 嵌入式硬件中MOSFET基本原理与实现
  • 区块链技术原理(2) -数据结构
  • 嵌入式硬件中MOSFET基本控制详解
  • 「iOS」————自动释放池底层原理
  • 基于Python+Vue+Mysql实现(物联网)智能大棚
  • C 语言主控开发与显控开发能力体系及技术栈详解,STM32、QT、嵌入式、边缘系统显示
  • Spring、Spring MVC、MyBatis 和 Spring Boot的关系
  • STM32U5 周期性异常复位问题分析
  • 物联网架构全解析:华为“1+2+1”与格行随身WiFi,技术如何定义未来生活?
  • JVM学习日记(十七)Day17——性能监控与调优(四)
  • .NET9 AOT完全自举了吗?
  • .NET 10 新增功能系列文章5——C# 14 中的新增功能
  • Unity URP渲染管线动态修改材质球状态
  • 38.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--扩展功能--增加日志记录器
  • 十八、k8s细粒度流量管理:服务网格
  • 虚幻GAS底层原理解剖八 (自定义子类)
  • 深入剖析Java线程:从基础到实战(上)
  • Clock斗篷技术:助力跨境电商营销推广的智慧策略
  • 技术优势铸就行业标杆:物联网边缘计算网关凭何引领智能变革?
  • 以 Eland 玩转 Elasticsearch 8.12 Learning-to-Rank
  • 嵌入式C语言编程:策略模式、状态模式和状态机的应用
  • 蓝凌EKP产品:列表查询性能优化全角度
  • Git 文件删除操作指南:管理与恢复已删除文件
  • 合约收款方式,转账与问题安全
  • 「耘•学社」耘少年第五期学能突破导师制领袖特训营,圆满落幕
  • 计算机视觉前言-----OpenCV库介绍与计算机视觉入门准备
  • 解决Git提交人信息默认全局化问题:让提交人自动关联当前用户
  • Element Plus实现分页查询
  • 【PHP 中的 `use` 关键字完全指南】