跳过内容

自动更新

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

确保您的捆绑包通过 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发送一个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 key应以 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响应,以确保插件在安装前可以验证捆绑包完整性。