Auto Update
复制安装步骤和完整的 Markdown 指南以获取此插件。
本文档将解释如何运行您的自动更新服务器。
服务您的捆绑包
标题为“服务您的捆绑包”确保您的捆绑包通过 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,