自定义存储
复制一个设置提示,包含安装步骤和此插件的完整Markdown指南。
Capgo 支持自定义存储解决方案来管理您的应用程序包,允许您在自己的基础设施或第三方存储服务上托管更新。这对于具有特定安全要求、合规需求或现有存储基础设施的组织来说尤其有用。
Capgo 中的自定义存储通过将您的包上传到外部位置并提供 Capgo 访问该包的 URL 来工作。Capgo SDK 将从您的自定义存储位置下载更新,而不是从 Capgo 的默认云存储。
外部URL上传
外部URL上传使用自定义存储的最简单方法是将捆绑包上传到任何可公开访问的URL,并将该URL提供给Capgo。
基本外部URL上传
外部URL上传npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip此命令告诉Capgo引用指定的URL中的捆绑包,而不是将其上传到Capgo的云存储。
带加密
带有标题“带加密”为了安全的外部存储,您可以对捆绑包进行加密,并提供解密密钥:
npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip --iv-session-key YOUR_IV_SESSION_KEYS3集成
带有标题“S3集成”Capgo内置支持Amazon S3和S3兼容存储服务。CLI可以自动将捆绑包上传到S3,并配置Capgo使用S3 URL。
S3上传选项
带有标题“S3上传选项”npx @capgo/cli@latest bundle upload \ --s3-region us-east-1 \ --s3-apikey YOUR_ACCESS_KEY \ --s3-apisecret YOUR_SECRET_KEY \ --s3-bucket-name your-bucket-name完成 S3 配置
标题:完成 S3 配置对于 S3 兼容服务或自定义端点:
npx @capgo/cli@latest bundle upload \ --s3-region us-east-1 \ --s3-apikey YOUR_ACCESS_KEY \ --s3-apisecret YOUR_SECRET_KEY \ --s3-endpoint https://s3.your-provider.com \ --s3-bucket-name your-bucket-name \ --s3-port 443 \ --no-s3-ssl # Only if your endpoint doesn't support SSLS3 配置参数
标题:S3 配置参数| 参数 | 描述 | 必填 |
|---|---|---|
--s3-region | S3 存储桶的 AWS 区域 | 是 |
--s3-apikey | S3 访问密钥 ID | 是 |
--s3-apisecret | S3 密钥访问密钥 | 是 |
--s3-bucket-name | S3 存储桶的名称 | 是 |
--s3-endpoint | 自定义 S3 端点 URL | 否 |
--s3-port | S3 端点的端口 | 否 |
--no-s3-ssl | 禁用 S3 上传的 SSL | 否 |
打包准备和加密
标题:打包准备和加密当使用自定义存储,特别是加密时,您需要正确准备您的打包。 这涉及创建一个 zip 文件并可选地加密它。
步骤 1:创建 zip 打包
标题:步骤 1:创建 zip 打包首先,创建一个 zip 文件的应用程序打包:
npx @capgo/cli@latest bundle zip com.example.app --path ./distzip 命令将返回 zip 文件的校验和。 您可以使用此校验和加密 zip 文件,如果需要。 使用 --json 选项以获取结构化输出,包括校验和。
压缩命令选项
标题:压缩命令选项npx @capgo/cli@latest bundle zip [appId] \ --path ./dist \ --bundle 1.2.3 \ --name myapp-v1.2.3 \ --json \ --no-code-check \ --key-v2 \ --package-json ../../package.json,./package.json| 选项 | 描述 |
|---|---|
--path | 压缩的文件夹路径(默认为capacitor.config中的webDir) |
--bundle | 打包版本号以命名压缩文件 |
--name | 自定义压缩文件名 |
--json | 以JSON格式输出结果(包括校验和) |
--no-code-check | 跳过检查notifyAppReady()调用和索引文件 |
--key-v2 | 使用加密v2 |
--package-json | 多仓库项目的package.json文件路径(逗号分隔) |
步骤 2:加密打包文件(可选)
步骤 2:加密打包文件(可选)为了增强安全性,请在上传之前加密您的 zip 打包文件:
# Using default local keynpx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM
# Using custom key filenpx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM --key ./path/to/.capgo_key_v2
# Using key data directlynpx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM --key-data "PRIVATE_KEY_CONTENT"The CHECKSUM 此参数是必需的,应为您的 zip 文件的校验和。您可以从 zip 命令输出中获取校验和(使用 --json 加密命令默认会使用您的本地私钥。您可以使用
或 --key 选项指定自定义密钥。 --key-data Paths to package.json files for monorepos (comma separated) __CAPGO_KEEP_0__
The encrypt command will return the ivSessionKey needed for upload or decryption.
加密命令选项
加密命令选项| 选项 | 描述 |
|---|---|
zipPath | 加密的 zip 文件路径(必填) |
checksum | zip 文件的校验和(必填) - 从 zip 命令获取 |
--key | 自定义私钥路径(可选,使用本地私钥) |
--key-data | 私钥数据(可选) |
--json | 输出结果以 JSON 格式 |
完整工作流程示例
名为“完整工作流程示例”的部分示例 1:带加密的外部 URL
名为“示例 1:带加密的外部 URL”的部分-
构建您的应用:
终端窗口 npm run build -
创建 zip 压缩包:
终端窗口 npx @capgo/cli@latest bundle zip com.example.app --path ./dist --bundle 1.2.3注意此命令返回的校验和。
-
加密包:
终端窗口 npx @capgo/cli@latest bundle encrypt ./com.example.app-1.2.3.zip CHECKSUM_FROM_STEP_2注意
ivSessionKey从输出中获取。 -
上传到您的存储: 将加密的zip文件上传到您的托管服务。
-
注册到Capgo:
终端窗口 npx @capgo/cli@latest bundle upload \--external https://your-cdn.com/bundles/com.example.app-1.2.3.zip \--iv-session-key IV_SESSION_KEY_FROM_STEP_3
示例 2:直接 S3 上传
标题:示例 2:直接 S3 上传-
构建您的应用:
终端窗口 npm run build -
直接上传到 S3:
终端窗口 npx @capgo/cli@latest bundle upload \--s3-region us-west-2 \--s3-apikey YOUR_ACCESS_KEY \--s3-apisecret YOUR_SECRET_KEY \--s3-bucket-name your-app-bundles \--channel Production
示例 3:带加密的 S3
标题:示例 3:带加密的 S3-
构建并压缩:
终端窗口 npm run buildnpx @capgo/cli@latest bundle zip com.example.app --path ./dist --key-v2 -
加密打包:
终端窗口 npx @capgo/cli@latest bundle encrypt ./com.example.app.zip CHECKSUM -
加密并上传到 S3:
终端窗口 npx @capgo/cli@latest bundle upload \--s3-region us-west-2 \--s3-apikey YOUR_ACCESS_KEY \--s3-apisecret YOUR_SECRET_KEY \--s3-bucket-name your-app-bundles \--iv-session-key IV_SESSION_KEY_FROM_STEP_2 \--channel Production
安全注意事项
安全注意事项在使用自定义存储时,请考虑以下安全最佳实践:
- 确保您的存储 URL 可以让您的应用用户访问,但不应让公众发现
- 在可能的情况下使用签名 URL 或基于令牌的身份验证
- 为基于 Web 的应用程序实现适当的 CORS 头
- 始终使用 Capgo 加密工具加密敏感的捆绑包
- 安全存储加密密钥并定期轮换
- 为所有捆绑包 URL 使用 HTTPS(移动和 Electron 应用程序所必需)
- 监控访问日志以检测异常下载模式
- 设置下载失败的捆绑包的警报
- 定期检查存储权限
故障排除
故障排除常见问题
常见问题捆绑包下载失败:
- 验证 URL 公开可访问且使用 HTTPS(对于移动和 Electron 应用程序必需)
- 检查 Web 应用程序的 CORS 头
- 确保捆绑包格式正确
加密错误:
- 验证
ivSessionKey匹配加密的捆绑包 - 检查捆绑包是否使用正确的密钥进行加密
- 确保新捆绑包使用加密 v2
S3 上传失败:
- 验证您的 S3 凭据和权限
- 检查桶策略和 CORS 配置
- 确保指定的区域是正确的
调试命令
调试命令检查捆绑包状态:
npx @capgo/cli@latest app debug验证捆绑包完整性:
npx @capgo/cli@latest bundle list下一步
名为“下一步”的小节继续自定义存储
继续自定义存储如果您正在使用 自定义存储 来规划安全性和合规性,连接它与 加密 加密的实现细节在 合规 合规的实现细节在 Capgo 安全扫描器 为产品工作流程在Capgo安全扫描器中 Capgo安全 为产品工作流程在Capgo安全中,和 Capgo信任中心 为产品工作流程在Capgo信任中心中。