跳过内容

Auto Update

GitHub

本文档将解释如何运行您的自动更新服务器。

确保您的捆绑包通过 HTTPS 服务,并且服务器有正确的 CORS 头来允许应用程序下载更新。 例如: https://myserver.com/app/updates/updates.json

如果您不熟悉如何服务一个捆绑包,我们建议您尝试 Capgo Cloud 或查看以下示例:

添加一个 updateUrl 到您的 capacitor.config.json.

{
"plugins": {
"CapacitorUpdater": {
"updateUrl": "https://myserver.com/app/updates/updates.json",
}
}
}

更新 API

《更新API》

每次打开应用时,插件将向您的API发送一个POST请求,请求体如下:

interface AppInfos {
"platform": "ios" | "android" | "electron",
"device_id": "UUID_of_device_unique_by_install",
"app_id": "APPID_FROM_CAPACITOR_CONFIG",
"custom_id": "your_custom_id_set_on_runtime",
"plugin_version": "PLUGIN_VERSION",
"version_build": "VERSION_NUMBER_FROM_NATIVE_CODE",
"version_code": "VERSION_CODE_FROM_NATIVE_CODE",
"version_name": "LAST_DOWNLOADER_VERSION" | "builtin"
"version_os": "VERSION_OF_SYSTEM_OS",
"is_emulator": boolean,
"is_prod": boolean,
}

服务器API应以JSON格式响应capacitor-updater插件。 如果有更新:

{
"version": "1.2.3",
"url": "https://myserver.com/app/updates/my-new-app-2.0.0.zip",
"checksum": "sha256_checksum_of_bundle"
}

在自动更新模式下,服务器应比较版本并返回正确的版本,如果URL键存在,插件将启动下载过程。

如果您添加“message”和“error”键,版本将不会被设置,消息将在日志中显示而不是版本。

version 键应以 semver 格式保存。

zip文件应具有 index.html 作为根文件夹中的文件,或根文件夹中仅有一个文件夹,且 index.html 文件夹内。

您可以使用命令CLI来压缩您的捆绑包:

创建一个包含您文件的捆绑包,以便从您的服务器中服务
npx @capgo/cli bundle zip --path [/path/to/my/bundle]

生成捆绑包校验和

标题:生成捆绑包校验和

重要: 您必须使用Capgo CLI来创建您的捆绑包zip文件。Capgo插件需要特定的zip格式和结构,只有当使用官方CLI工具时才会保证。标准zip工具可能会创建不兼容的存档。

要为您的捆绑包生成校验和,请使用Capgo CLI zip命令并使用标志: --json 标志:

创建带有校验信息的捆绑包
npx @capgo/cli bundle zip [appId] --json

此命令将:

  • 创建一个与Capgo插件兼容的格式化zip文件
  • 为完整性验证生成SHA256校验和
  • 以JSON格式输出捆绑包信息

示例输出:

{
"version": "1.2.3",
"checksum": "a1b2c3d4e5f6789...",
"size": 1234567
}

使用 checksum 从此输出中获取值并将其用于API响应,以确保捆绑包在安装前可以由插件验证完整性。

继续从Auto Update

如果您正在使用

Auto Update 来规划迁移和企业运营,连接它 Auto Update 使用 @capgo/capacitor-updater 使用 @capgo/capacitor-updater Capgo 企业版 Capgo 企业版 Ionic 企业插件替代方案 __CAPGO_KEEP_0__ 替代方案 Capgo 咨询 for the product workflow in Capgo Alternatives, and Capgo Consulting for the native capability in Using @Capgo/__CAPGO_KEEP_1__-updater,