news 2026/4/23 13:58:14

Electron项目使用electron-updater与UpgradeLink接入参考

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Electron项目使用electron-updater与UpgradeLink接入参考

Electron项目使用electron-updater与UpgradeLink接入参考

一、官方组件electron-updater介绍

Electron官方提供的electron-updater组件支持通过更新服务器或静态文件实现应用程序的自动更新,核心功能包括:

  • 兼容Electron更新协议的版本检查
  • 跨平台的安装包下载与安装流程
  • 灵活的更新策略配置

核心资源

  • 官方文档地址: 文档
  • UpgradeLink Api地址: 文档

整体逻辑:通过调用UpgradeLink提供的API获取升级策略,由electron-updater组件执行具体的更新流程,实现与官方更新体系的无缝对接。

接入流程图

二、接入核心步骤

可用来参考的 electron-demo项目地址

1. 安装官方更新组件

  • updater组件使用指南

2. 阅读官方动态更新服务器文档,了解接入流程。文档地址

UpgradeLink 提供了 获取更新 api,完全兼容了官方要求的请求参数与返回结构。可以进行无缝的替换。

3. 添加 dev-update.yml 文件,用来配置出 更新包下载地址

provider: generic updaterCacheDirName: electron-demo-updater # 下载目录

4. 代码替换, 调整检查更新 方法。

基于官方提供的 检查更新 代码,我们只需要在官方提供的 checkForUpdates 方法中,替换为 UpgradeLink 提供的接口地址即可。

// 打印相关参数 console.log(app.getVersion()); console.log(process.platform); console.log(process.arch); const FeedURL = `https://api.upgrade.toolsetlink.com/v1/electron/upgrade?electronKey=kPUtUMDIjBhS48q5771pow&versionName=${app.getVersion()}&appointVersionName=&devModelKey=&devKey=&platform=${process.platform}&arch=${process.arch}`; autoUpdater.setFeedURL({ url: FeedURL, provider: 'generic', }); autoUpdater.requestHeaders = { 'X-AccessKey': 'mui2W50H1j-OC4xD6PgQag', }; const result = await autoUpdater.checkForUpdates(); // 打印返回结果 console.log("result: ",result);

4.代码替换, 调整 下载并更新 方法, 调整下载地址为检查更新接口返回的地址。

const FeedURL = `https://api.upgrade.toolsetlink.com/v1/electron/upgrade?electronKey=kPUtUMDIjBhS48q5771pow&versionName=${app.getVersion()}&appointVersionName=&devModelKey=&devKey=&platform=${process.platform}&arch=${process.arch}`; autoUpdater.setFeedURL({ url: FeedURL, provider: 'generic', }); autoUpdater.requestHeaders = { 'X-AccessKey': 'mui2W50H1j-OC4xD6PgQag', }; const result = await autoUpdater.checkForUpdates(); // 打印检查更新接口返回结果 console.log(result); autoUpdater.setFeedURL({ url: result.updateInfo.path, provider: 'generic', }); console.log('[流程] 下载更新开始,URL:', result.updateInfo.path); try { await autoUpdater.downloadUpdate(); console.log('[流程] 下载更新完成'); } catch (e) { console.error('[流程] 下载更新失败:', e); console.error('[DEBUG] 错误堆栈:', e.stack); throw e; }

更新协议的请求参数(如platformarch)和响应结构,UpgradeLink完全兼容官方规范,可直接替换使用。

以上是接入指南。如果需要调整内容详略或补充特定场景说明,欢迎告知具体需求。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 13:54:10

团队 Daily Scrum:2025年12月11日(Beta Day 15)

项目阶段:UI与核心功能联调(昨晚忙忘了)今日进度孙崇景工作进展:将核心识别算法与UI界面连接,实现了“一键识别”按钮的真实功能。遇到的困难:前后端数据传输格式不匹配,导致解析失败。下一步计划:修复数据…

作者头像 李华
网站建设 2026/4/18 10:40:04

Duplicacy智能缓存技术揭秘:如何实现秒级增量备份

Duplicacy智能缓存技术揭秘:如何实现秒级增量备份 【免费下载链接】duplicacy A new generation cloud backup tool 项目地址: https://gitcode.com/gh_mirrors/du/duplicacy 在当今数据爆炸的时代,高效的备份解决方案已成为企业数据安全的生命线…

作者头像 李华
网站建设 2026/4/23 13:54:23

Visual C++运行库智能诊断与修复系统使用指南

Visual C运行库智能诊断与修复系统使用指南 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 请基于VisualCppRedist AIO工具集的功能特性,撰写一篇面向…

作者头像 李华
网站建设 2026/4/23 13:52:57

终极革命:Qwen-Edit-2509多视角插件如何重塑AI视觉创作工作流

终极革命:Qwen-Edit-2509多视角插件如何重塑AI视觉创作工作流 【免费下载链接】Qwen-Edit-2509-Multiple-angles 项目地址: https://ai.gitcode.com/hf_mirrors/dx8152/Qwen-Edit-2509-Multiple-angles 还在为传统图像编辑工具的视角局限而困扰?…

作者头像 李华
网站建设 2026/4/23 12:48:25

测试人员的产品思维培养

当测试遇见产品思维 在数字化转型浪潮中,软件测试不再只是质量守门人,更应成为用户体验的捍卫者与业务价值的共创者。据统计,具备产品思维的测试团队能使产品上线后的用户投诉率降低42%,需求回溯准确率提升57%(2024年…

作者头像 李华