跳过主要内容
CI/CD

自动Capacitor IOS构建

使用Codemagic和Codemagic在5分钟内为您的IOS Ionic应用设置CI/CD管道(2024)

马丁·多纳迪厄

马丁·多纳迪厄

内容营销人员

使用 Codemagic 自动构建 Capacitor iOS

使用 Codemagic 实现 iOS 的持续交付

前提条件

继续教程之前,请注意…

  • iOS 开发者计划会员资格
  • 想看😆…

关于价格的重要信息

Codemagic Action 的价格

https://codemagic.io/pricing/

该服务的价格是…免费' 每月根据选择的机器,最高可获得 500 分钟 macOS M1 时间
我们将使用一个 macOS M1 机器,截图中可以看到其价格和限制(价格截至教程创建时间,可能会在未来发生变化)

🔴 一旦警告了要求和价格,如果您喜欢,我们继续…

📣 在文章中,我们假设我们已经在 iTunes Connect 中创建了应用,拥有 Apple 生态系统的证书,Codemagic 将为我们设置一切!

让我们开始探索!

文章中的步骤

  1. 使用 App Store Connect API 与 Codemagic
  2. 要求
  3. 创建 App Store Connect API 密钥
  4. 使用 App Store Connect API 密钥
  5. 复制 Fastlane 文件
  6. 配置 Codemagic

1. 使用 App Store Connect API 与 Codemagic

2021 年 2 月起,所有用户必须使用两步验证或两因素验证登录 App Store Connect。这种额外的安全层对于您的 Apple ID 有助于确保您是唯一能够访问帐户的人。
来自 Apple 支持

使用 match 开始需要您撤销现有的证书。但是,不用担心,您将直接获得新的证书。

要求

要使用 App Store Connect API,Codemagic 需要 三个 东西

  1. 发行者 ID。
  2. 密钥 ID。
  3. 密钥文件或密钥内容。

创建 App Store Connect API 密钥

要生成密钥,您必须在 App Store Connect 中具有管理员权限。如果您没有该权限,请将相关人员指向此文章并遵循以下说明。

1 — 登录到 App Store Connect.

2 — 选择 用户和访问.

App Store Connect 用户访问

3 — 选择 API 密钥选项卡。

App Store Connect API 密钥

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

App Store Connect API 密钥创建

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

App Store Connect API 密钥创建名称

6 — 点击生成。

一个 API 密钥的访问权限不能限制到特定的应用。

页面上显示新密钥的名称、密钥 ID、下载链接和其他信息。

App Store Connect 下载密钥

获取以下三个必要信息: 1> 问题 ID。
2> 密钥 ID。
<3> 点击 “下载 API 密钥” 下载您的 API 私钥。下载链接仅在私钥尚未下载时才会出现。苹果公司不会保留私钥的副本。因此,您只能下载一次。

🔴 请将您的私钥存储在安全的地方。您不应共享您的密钥、将密钥存储在 code 仓库中或将密钥包含在客户端 code 中。

在 Codemagic 中添加 App Store Connect API 密钥

  1. 打开您的 Codemagic 团队设置 选择团队集成 打开团队 选择 code 签名身份 选择 code 签名身份 并上传证书 上传证书

  2. 点击 添加密钥 button.

  3. 输入 App Store Connect API key name. 这是用于应用设置中后续引用此键的可读名称。

  4. 输入 Issuer IDKey ID 值。

  5. 点击 选择一个 .p8 文件 或将 App Store Connect API 键下载的文件拖拽到上传。

  6. 点击 保存.

现在我们可以使用 App Store Connect API 键管理 Codemagic,太棒了!

2. 创建证书和配置文件

证书

打开 XCode 并前往 设置 > 账户 > Apple ID > 团队 并选择您的团队。

Code 签名身份

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

苹果分发

然后你可以创建一个新的证书。

然后你需要去钥匙串下载证书作为一个 .p12 文件。

为了实现这一点,你需要去钥匙串切换到 登录 钥匙串,然后切换到 我的证书.

我的证书

然后你可以选择你要下载的证书。(查看证书的日期)

然后右键单击证书并选择 导出.

选择文件格式 个人信息交换 (.p12).

将下载证书作为 .p12 文件。

分发配置文件

打开 Apple Developer 并选择正确的团队。

然后创建一个新配置文件,点击 +

创建新配置文件

并选择 App Store Connect.

选择 App Store Connect

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

选择正确的应用程序

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

选择正确的证书

最后输入配置文件的名称并点击 生成.

配置文件的名称将用于在 Codemagic 中识别配置文件。

生成配置文件

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

下载配置文件

添加Code签名证书

Codemagic允许您上传code签名证书作为包含证书和私钥的PKCS#12存档。上传时,Codemagic将要求您提供证书密码(如果证书受密码保护),以及一个唯一的 参考名称,然后可以在 codemagic.yaml 配置中使用它来获取特定的文件。

  • 上传证书
  • 生成新证书
  • 从开发者门户获取
  1. 打开您的Codemagic团队设置,前往 codemagic.yaml设置 > Code 签名身份.
  2. 开启 iOS 证书 选项卡。
  3. 通过点击 选择一个 .p12 或 .pem 文件 或将其拖拽到指示框架中。
  4. 输入 证书密码 并选择一个 参考名称.
  5. 点击 添加证书

添加分发配置文件

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. 触发工作流程

触发工作流程

将新提交推送到分支 maindevelopment 手动触发工作流程。

使用以下提交开始

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

Testflight 控制台

手动启动

您可以手动启动工作流程。

首先选择要构建的应用,然后点击 新建构建.

选择应用

然后选择要构建的分支。

选择分支

点击 开始新建.

然后去你建的列表

建的列表

点击建的项目查看结果

建的结果

可以从本地机器部署

是的,你可以,而且非常方便

你可以使用Xcode来构建和签名你的应用,和之前一样

感谢

本博客基于以下文章:

Capacitor 应用的实时更新

当有 web 层 bug 在 live 时,通过 Capgo 将修复推送给用户,而不是等待几天的 app store 审批。用户在后台接收更新,而原生变化仍在正常的审批路径中。

立即开始

最新博客

Capgo 为您提供了创建真正专业的移动应用所需的最佳见解。