使用 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 开发者计划角色权限 这里

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

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

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

点击 管理证书 > + 并选择 苹果分发.

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

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

并选择 App Store Connect.

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

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

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

你可以下载配置文件 .mobileprovision 文件.

添加Code签名证书
Codemagic允许您上传code签名证书作为包含证书和私钥的PKCS#12存档。上传时,Codemagic将要求您提供证书密码(如果证书受密码保护),以及一个唯一的 参考名称,然后可以在 codemagic.yaml 配置中使用它来获取特定的文件。
- 上传证书
- 生成新证书
- 从开发者门户获取
- 打开您的Codemagic团队设置,前往 codemagic.yaml设置 > Code 签名身份.
- 开启 iOS 证书 选项卡。
- 通过点击 选择一个 .p12 或 .pem 文件 或将其拖拽到指示框架中。
- 输入 证书密码 并选择一个 参考名称.
- 点击 添加证书
添加分发配置文件
Codemagic允许您上传用于应用程序的分发配置文件或从Apple Developer Portal中获取配置文件。
添加到Code签名身份的配置文件的类型、团队、包ID和过期日期均被显示。此外,Codemagic将告知您是否在code签名身份中存在匹配的Code签名证书(配置文件字段中的绿色勾)或否。 证书 3. 配置Codemagic
配置Codemagic密钥
您是否曾经想知道这些值的来源?答案不再是秘密了,它来自您的项目的密钥。 🤦
4. 配置Codemagic工作流文件 ENV 创建一个名为
的文件
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 应用程序。
每次您发送新的标签时,测试飞行中的发布将被构建。
您的应用程序不需要使用Ionic,只需使用 Capacitor 基础即可,应用程序可以使用旧的Cordova模块,但应优先使用 Capacitor JS插件。
5. 触发工作流程
触发工作流程
将新提交推送到分支 main 或 development 手动触发工作流程。

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

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

然后选择要构建的分支。

点击 开始新建.
然后去你建的列表

点击建的项目查看结果

可以从本地机器部署
是的,你可以,而且非常方便
你可以使用Xcode来构建和签名你的应用,和之前一样
感谢
本博客基于以下文章: