使用 Codemagic 的 iOS 持续交付
前提条件
继续教程之前…
- iOS 开发者计划会员资格
- 愿意阅读 😆…
关于价格的重要信息

该服务是 ‘免费的 每月至多 500 个 macOS M1 分钟,具体取决于所选机器。
我们将使用一个 macOS M1 机器,您可以在截图中看到其价格和限制(截至教程创建时的价格,可能会在未来发生变化)
🔴 一旦警告了要求和价格,如果您喜欢,我们继续…
📣 在文章中,我们假设我们已经在 iTunes Connect 中创建了应用,我们已经拥有 Apple 生态系统的证书,Codemagic 将为我们设置一切!
让我们深入!
文章中要遵循的步骤
- 使用 App Store Connect API 与 Codemagic
- 要求
- 创建 App Store Connect API 密钥
- 使用 App Store Connect API 密钥
- 复制 Fastlane 文件
- 配置 Codemagic
1. 使用 App Store Connect API 与 Codemagic
从 2021 年 2 月开始,所有用户必须使用两因素认证或两步验证登录 App Store Connect。这种额外的安全层对于您的 Apple ID 有助于确保您是唯一可以访问帐户的人。
来自 Apple 支持
使用 match 开始需要撤销您的现有证书。但是,不用担心,您将直接获得新的证书。
要求
要能在 App Store Connect 中使用 API, Codemagic 需要 三个 事项。
- 发行者 ID。
- 密钥 ID。
- 密钥文件或密钥内容。
创建 App Store Connect API 密钥
要生成密钥,您必须在 App Store Connect 中具有管理员权限。如果您没有该权限,请将相关人员指向此文章并遵循以下说明。
1 — 登录 App Store Connect.
2 — 选择 用户和访问.

3 — 选择 API 密钥选项卡。

4 — 点击生成 API 密钥或添加 (+) 按钮。

5 — 为密钥输入名称并选择访问级别。我们建议选择 App Manager 访问权限,了解更多关于 Apple Developer Program 角色权限 这里

6 — 点击生成。
一个 API 密钥的访问权限无法限制到特定的应用。
新密钥的名称、密钥 ID、下载链接和其他信息将出现在页面上。

请在此处获取所有三个必要的信息:
1. 问题ID.
2. 密钥ID.
3. 点击“下载API密钥”以下载您的API私钥。下载链接仅在私钥尚未下载时才会出现。Apple不会保留私钥的副本。因此,您只能下载一次。
🔴 将您的私钥存储在安全的地方。您不应共享您的密钥,存储密钥在code仓库中,或者在客户端code中包含密钥。
将App Store ConnectAPI密钥添加到Codemagic
-
打开您的Codemagic团队设置
选择code签名身份
并上传证书

-
点击 添加密钥 按钮。
-
输入
App Store Connect API key name。该密钥的名称将用于在应用设置中引用密钥。 -
输入
Issuer ID和Key ID值。 -
点击 选择一个 .p8 文件 或将 App Store Connect API 密钥下载的文件拖拽到上传。
-
Click Save.
现在我们可以使用App Store Connect的API密钥来管理Codemagic,太棒了!
2. 创建证书和配置文件
证书
打开XCode,前往 设置 > 账户 > Apple ID > 团队 并选择您的团队。

点击 管理证书 > + 并选择 Apple Distribution.

然后您可以创建一个新的证书。
然后您需要去钥匙串下载证书作为 .p12 文件。
要做到这一点,您需要切换到 登录 钥匙串,然后 我的证书.

然后您可以选择要下载的证书(按证书日期排序)
然后右键点击证书并选择 导出.
选择文件格式 个人信息交换 (.p12) .
这将下载证书作为 .p12 文件。
配置文件
打开 Apple Developer 并选择正确的团队。
然后创建一个新配置文件,点击 +

并选择 App Store Connect.

然后需要选择正确的应用程序,注意不能使用通配符否则签名会失败。

选择您之前创建的正确证书(查找有效期日期,应与今天相同的日期和月份),并点击 继续.

最后输入配置文件的名称并点击 生成.
将用于识别配置文件的名称。

您可以下载配置文件作为一个 .mobileprovision 文件。

添加Code签名证书
Codemagic允许您上传code签名证书作为包含证书和私钥的PKCS#12存档。上传时,Codemagic将要求您提供证书密码(如果证书受密码保护)以及一个唯一的 参考名称,以便在 codemagic.yaml 配置中使用它来获取特定文件。
- 上传证书
- 生成新证书
- 从开发者门户获取
- 打开您的Codemagic团队设置,前往 codemagic.yaml设置 > Code签名身份.
- 打开 iOS证书 选项卡。
- 将证书文件上传到指定框中,点击 选择一个.p12或.pem文件 或将其拖拽到指示框中。
- 输入 证书密码 and choose a Reference name.
- Click Add certificate
Adding the provisioning profile
Codemagic允许您上传用于应用程序的配置文件或从Apple Developer Portal中获取配置文件。
配置文件的类型、团队、包ID和过期日期将为每个添加到Code签名身份的配置文件显示。另外,Codemagic将告知您是否在code签名身份中有匹配的Code签名证书(签名身份中绿色勾选的字段)或否。 3. Setup Codemagic Configure Codemagic secrets
Ever wonder where the values of the
3. Setup Codemagic
Configure Codemagic secrets ENV 是从哪里来的呢?答案不再是秘密了 – 来自你的项目的密钥。 🤦
4. 配置 Codemagic 工作流文件
创建一个名为 codemagic.yml 在你的项目根目录下添加以下内容。
workflows:
ionic-capacitor-ios-workflow:
name: Capacitor iOS Workflow
max_build_duration: 120
instance_type: mac_mini_m1
integrations:
app_store_connect: CodeMagic
environment:
ios_signing:
distribution_type: app_store
bundle_identifier: YOUR_BUNDLE_IDENTIFIER
vars:
XCODE_WORKSPACE: ios/App/App.xcworkspace
XCODE_SCHEME: App
APP_STORE_APP_ID: YOUR_APP_STORE_APP_ID
node: v20.14.0
xcode: 15.4
cocoapods: default
triggering:
events:
- tag
tag_patterns:
- pattern: '*'
include: true
scripts:
- name: Install dependencies
script: |
npm install
- name: Cocoapods installation
script: |
cd ios/App && pod install
- name: Update dependencies and copy web assets to native project
script: |
npm run build
npx cap sync ios
- name: Set up code signing settings on Xcode project
script: |
xcode-project use-profiles
- name: Increment build number
script: |
cd $CM_BUILD_DIR/ios/App
LATEST_BUILD_NUMBER=$(app-store-connect get-latest-app-store-build-number "$APP_ID")
agvtool new-version -all $(($LATEST_BUILD_NUMBER + 1))
- name: Build ipa for distribution
script: |
xcode-project build-ipa \
--workspace "$XCODE_WORKSPACE" \
--scheme "$XCODE_SCHEME"
artifacts:
- build/ios/ipa/*.ipa
- /tmp/xcodebuild_logs/*.log
- $HOME/Library/Developer/Xcode/DerivedData/**/Build/**/*.app
- $HOME/Library/Developer/Xcode/DerivedData/**/Build/**/*.dSYM
publishing:
email:
recipients:
- YOUR_EMAIL
notify:
success: true # To not receive a notification when a build succeeds
failure: false # To not receive a notification when a build fails
app_store_connect:
auth: integration
# Configuration related to TestFlight (optional)
# Note: This action is performed during post-processing.
submit_to_testflight: true
# Configuration related to App Store (optional)
# Note: This action is performed during post-processing.
submit_to_app_store: false
这个工作流应该在手动或每次 GitHub 标签,如果你需要自动化标签,请参阅 自动构建和发布与 GitHub 动作 首先。
然后这个工作流将拉取 NodeJS 依赖项,安装它们并构建你的 JavaScript 应用程序。
每次你发送一个新的标签,一个测试版将在 TestFlight 中构建。
你的 App 不需要使用 Ionic,只需使用 Capacitor 基础即可,且可以使用旧的 Cordova 模块,但 Capacitor JS 插件应优先使用。
5. 触发工作流
触发工作流
将新提交推送到分支 main 或 development 以触发工作流

几分钟后,构建应该可在您的 App Store Connect 控制台中找到。

手动启动
您可以手动启动工作流。
首先选择要构建的应用,然后点击 手动启动新构建.

然后选择您要构建的分支。

然后点击 开始新建.
然后去查看构建列表

然后点击构建以查看结果

可以从本地机器部署
是的,您可以,而且这很容易。
您可以使用 Xcode 构建和签署您的应用,如常规一样。
感谢
本博客基于以下文章:
从自动 Capacitor IOS 构建中继续前进,使用 Codemagic
如果您正在使用 使用 Codemagic 的自动 Capacitor IOS 构建 来规划 CI/CD 自动化,连接它到 Capgo CI/CD 为产品工作流程在 Capgo CI/CD 中 Capgo 原生构建 为产品工作流程在Capgo原生构建中 Capgo集成 为产品工作流程在Capgo集成中 CI/CD集成 为CI/CD集成的实现细节,和 GitHub动作集成 为GitHub动作集成的实现细节。