electron-updater软件自动检测更新 +无服务器本地测试

news2025/2/12 10:40:23

大家好,我是小黄。

今天分享一下如何0基础实现electron自动检测更新功能。

一. 安装 electron-updater 实现自动更新

安装依赖 electron-updater

npm install electron-updater

 二. 修改package.josn

 "publish": {
      "provider": "generic",
      "url": "http://127.0.0.1:8080"  
    }

 url为你的服务器地址。

三.修改main.js

注:代码不完整(完整版请关注小黄回复关键字:electron打包  获取)

const { app, BrowserWindow, ipcMain, dialog } = require('electron'); 
const { autoUpdater } = require('electron-updater');
const logger = require('electron-log');

// 设置日志记录
logger.transports.file.maxSize = 1002430; // 10M
logger.transports.file.format = '[{y}-{m}-{d} {h}:{i}:{s}.{ms}] [{level}]{scope} {text}';
logger.transports.file.resolvePath = () => './operation.log';
autoUpdater.autoDownload = false; // 设置为 false,防止自动下载

let progressWin = null;

function createWindow() {
  let mainWin = new BrowserWindow({
    show: false,
    width: 1200,
    height: 1000,
    autoHideMenuBar: true,
    resizable: true,
    minHeight: 200,
    minWidth: 300,
    title: 'test',
    webPreferences: {
      enableWebSQL: false,
      webSecurity: false,
      spellcheck: false,
      nativeWindowOpen: true,
      nodeIntegration: true,
      contextIsolation: false,
    },
  });

  mainWin.loadFile('./test.html');

  // 调试窗口
  // mainWin.webContents.openDevTools();

  // 延迟 1 秒后检查更新
  setTimeout(() => {
    checkForUpdates(mainWin);
  }, 1000);

  function checkForUpdates(win) {
    const updateUrl = 'http://127.0.0.1:8080';
    autoUpdater.setFeedURL(updateUrl);

    // 检查更新
    autoUpdater.checkForUpdates();

    // 更新错误事件
    autoUpdater.on('error', (error) => {
      console.error('检查更新出错:', error);
    });

    // 检查更新事件
    autoUpdater.on('checking-for-update', () => {
      console.log('正在检查更新...');
    });

    // 发现新版本
    autoUpdater.on('update-available', (info) => {
      const choice = dialog.showMessageBoxSync(win, {
        type: 'info',
        buttons: ['更新', '稍后'],
        title: '发现新版本',
        message: `检测到新版本 ${info.version},是否立即更新?`,
      });

      if (choice === 0) {
        // 用户选择更新,创建进度弹窗
        createProgressWindow();
        autoUpdater.downloadUpdate();
      }
    });

    // 当前版本为最新版本
    autoUpdater.on('update-not-available', () => {
      console.log('当前版本已经是最新版本。');
    });

    // 下载进度事件
    autoUpdater.on('download-progress', (progress) => {
      const message = `已下载 ${Math.round(progress.percent)}% (${progress.transferred}/${progress.total})`;
      console.log(message);
      if (progressWin) {
        progressWin.webContents.send('progress', progress.percent);
      }
    });

    // 下载完成事件
    autoUpdater.on('update-downloaded', () => {
      if (progressWin) {
        progressWin.close();
        progressWin = null;
      }
      const choice = dialog.showMessageBoxSync(win, {
        type: 'info',
        buttons: ['立即安装', '稍后安装'],
        title: '更新完成',
        message: '更新包已下载完成,是否立即安装并重启应用?',
      });

      if (choice === 0) {
        autoUpdater.quitAndInstall(); // 安装并退出应用
      }
    });
  }

  mainWin.once('ready-to-show', () => {
    mainWin.show();
  });

  mainWin.on('close', (e) => {
    e.preventDefault();
    const choice = dialog.showMessageBoxSync(mainWin, {
      type: 'question',
      buttons: ['取消', '关闭'],
      title: '确认关闭',
      message: '确定要关闭应用吗?',
    });
    if (choice === 1) {
      mainWin.destroy();
    }
  });
}

四. 打包

 注:--publish always 表示生成 latest.yml 文件并上传到指定的发布服务器。不然打包后可能没有latest.yml

五. 本地搭建测试的服务器

安装依赖http-server 

pnpm install -g http-server

修改版本version为1.0.1再次打包

新建一个文件夹test

在文件夹下面存放打包后的exe和latest.yml

使用命令行启动服务

http-server ./test -p 8080

启动成功后我们在浏览器访问一下

http://localhost:8080/latest.yml

出现下面的就代表成功了。 

 六. 实际测试

注:更新无法再调试阶段测试,需要打包安装后进行测试。

我们直接打开1.0.0版本的安装包,这样只要读取到有更高的版本electron就会提示更新。

 下载成功后就会提示是否安装了。

 

七.总结

常用用 API 和事件

  • autoUpdater.setFeedURL(url):设置远程更新服务器的 URL,URL 指向包含更新文件的服务器。

  • autoUpdater.checkForUpdates():启动更新检查流程,自动检测是否有新版本。

  • autoUpdater.on('checking-for-update'):当检查更新时触发,通常用于显示“正在检查更新...”的提示。

  • autoUpdater.on('update-available'):当发现新版本时触发,通常会弹出更新对话框,询问用户是否进行更新。

  • autoUpdater.on('update-not-available'):当当前版本已是最新时触发。

  • autoUpdater.on('download-progress'):当更新下载进度发生变化时触发,可以获取下载进度信息,用于更新进度条。

  • autoUpdater.on('update-downloaded'):当更新包下载完成时触发,通常会提示用户安装更新。

  • autoUpdater.quitAndInstall():下载完成后,可以调用此方法退出应用并安装新版本。

各位小伙伴还在BOSS直聘hr已读不回?!试试这个宝藏小程序!大家快看这里。

创作不易,各位帅气漂亮的小伙伴点个关注再走呗!!

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2250966.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux——实现一个简易shell】

黑暗中的我们都没有说话,你只想回家,不想你回家............................................................... 文章目录 前言 一、【shell工作过程】 二、【命令行参数】 2.1、【获取命令行参数】 1、【输出命令行提示符】 2、【输入命令行参数】 2…

【超全总结】深度学习分割模型的损失函数类别及应用场景

《------往期经典推荐------》 一、AI应用软件开发实战专栏【链接】 项目名称项目名称1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】3.【手势识别系统开发】4.【人脸面部活体检测系统开发】5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】7.【…

新增工作台模块,任务中心支持一键重跑,MeterSphere开源持续测试工具v3.5版本发布

2024年11月28日,MeterSphere开源持续测试工具正式发布v3.5版本。 在这一版本中,MeterSphere新增工作台模块,工作台可以统一汇总系统数据,提升测试数据的可视化程度并增强对数据的分析能力,为管理者提供测试工作的全局…

大模型训练核心技术RLHF

本文此次的主要内容是使用强化学习训练语言模型的过程,特别是通过人类反馈的强化学习(RLHF)技术来微调大语言模型。本文先介绍了预训练模型的使用,然后重点介绍了RLHF的第二阶段,即将下游任务以特定数据集的形式交给大…

Python学习笔记之IP监控及告警

一、需求说明 作为一名运维工程师,监控系统必不可少。不过我们的监控系统往往都是部署在内网的,如果互联网出口故障,监控系统即使发现了问题,也会告警不出来,这个时候我们就需要补充监控措施,增加从外到内的…

联想YOGA Pro 14s至尊版电脑找不到独立显卡(N卡)问题,也无法安装驱动的问题

问题描述 电脑是联想YOGA Pro 14s至尊版,电脑上装的独立显卡是4060,一直是能够使用独立显卡的。然而有两次突然就找不到显卡了,NVIDIA CONTROL PANEL也消失了,而且也无法安装驱动。具体表现如下: 无法连接外接显示器…

【优先算法-滑动窗口——包含不超过两种字符的最长子串】

目录 1.题目解析 题目来源 测试用例 2.算法原理 1.入窗口 2.出窗口 3.更新结果 3.实战代码 代码解析 1.题目解析 题目来源 包含不超过两种字符的最长子串——牛客网 测试用例 2.算法原理 1.入窗口 这里的窗口限制条件为:窗口内不能超过两种字符,所以使用…

图片预处理技术介绍4——降噪

图片预处理 大家好,我是阿赵。   这一篇将两种基础的降噪算法。   之前介绍过均值模糊和高斯模糊。如果从降噪的角度来说,模糊算法也算是降噪的一类,所以之前介绍的两种模糊可以称呼为均值降噪和高斯降噪。不过模糊算法对原来的图像特征的…

Python蒙特卡罗MCMC:优化Metropolis-Hastings采样策略Fisher矩阵计算参数推断应用—模拟与真实数据...

全文链接:https://tecdat.cn/?p38397 本文介绍了其在过去几年中的最新开发成果,特别阐述了两种有助于提升 Metropolis - Hastings 采样性能的新要素:跳跃因子的自适应算法以及逆 Fisher 矩阵的计算,该逆 Fisher 矩阵可用作提议密…

cad软件打不开报错cad acbrandres dll加载失败

一切本来很顺利哒 但是,当我用快捷方式打开时,就出现了这个错误。进入文件路径,是有这个的; 在文件路径直接打开,也会提示错误 原因竟然是我改了个名字: 随便选的文件路径,空的,文件名为Acr…

HBU深度学习作业9

1. 实现SRN (1)使用Numpy实现SRN import numpy as npinputs np.array([[1., 1.],[1., 1.],[2., 2.]]) # 初始化输入序列 print(inputs is , inputs)state_t np.zeros(2, ) # 初始化存储器 print(state_t is , state_t)w1, w2, w3, w4, w5, w6, w7, …

泛化调用 :在没有接口的情况下进行RPC调用

什么是泛化调用? 在RPC调用的过程中,调用端向服务端发起请求,首先要通过动态代理,动态代理可以屏蔽RPC处理流程,使得发起远程调用就像调用本地一样。 RPC调用本质:调用端向服务端发送一条请求消息&#x…

纯Go语言开发人脸检测、瞳孔/眼睛定位与面部特征检测插件-助力GoFly快速开发框架

前言​ 开发纯go插件的原因是因为目前 Go 生态系统中几乎所有现有的人脸检测解决方案都是纯粹绑定到一些 C/C 库,如 ​​OpenCV​​ 或 ​​​dlib​​​,但通过 ​​​cgo​​​ 调用 C 程序会引入巨大的延迟,并在性能方面产生显著的权衡。…

基于SpringBoot实现的编程训练系统(代码+论文)

🎉博主介绍:Java领域优质创作者,阿里云博客专家,计算机毕设实战导师。专注Java项目实战、毕设定制/协助 📢主要服务内容:选题定题、开题报告、任务书、程序开发、项目定制、论文辅导 💖精彩专栏…

【Spring】Spring IOCDI:架构旋律中的“依赖交响”与“控制华章”

前言 🌟🌟本期讲解关于Spring IOC&DI的详细介绍~~~ 🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客 🔥 你的点赞就是小编不断更新的最大动力 🎆那么…

webpack(react)基本构建

文章目录 概要整体架构流程技术名词解释技术细节小结 概要 Webpack 是一个现代 JavaScript 应用程序的静态模块打包工具。它的主要功能是将各种资源(如 JavaScript、CSS、图片等)视为模块,并将它们打包成一个或多个输出文件,以便…

mysql--二进制安装编译安装yum安装

二进制安装 创建用户和组 [rootlocalhost ~]# groupadd -r -g 306 mysql [rootlocalhost ~]# useradd -r -g 306 -u 306 -d /data/mysql mysql 创建文件夹并添加所属文件用户和组 [rootlocalhost ~]# mkdir -p /data/mysql [rootlocalhost ~]# chown mysql:mysql /data/mysql …

DRM(数字权限管理技术)防截屏录屏----ffmpeg安装

提示:ffmpeg安装 文章目录 [TOC](文章目录) 前言一、下载二、配置环境变量三、运行ffmpeg四、文档总结 前言 FFmpeg是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。采用LGPL或GPL许可证。它提供了录制、转换以及流化音视频的…

MongoDB集群分片安装部署手册

文章目录 一、集群规划1.1 集群安装规划1.2 端口规划1.3 目录创建 二、mongodb安装(三台均需要操作)2.1 下载、解压2.2 配置环境变量 三、mongodb组件配置3.1 配置config server的副本集3.1.1 config配置文件3.1.2 config server启动3.1.3 初始化config …

小程序-基于java+SpringBoot+Vue的乡村研学旅行平台设计与实现

项目运行 1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA; 3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可 4.硬件环境&#xff1a…