Electron中文手册
  • 文档概述
  • 开发指南目录
  • 构建说明(Linux)
  • 构建说明(macOS)
  • 构建说明(Windows)
  • 构建系统概述
  • 编码规范
  • 在 macOS 中调试
  • 在 Windows 中调试
  • 在C ++代码中使用clang-format
  • 在调试器中设置符号服务器
  • 源代码目录结构
  • Chrome升级清单
  • Chromium 开发指南
  • V8 开发指南
  • 教程目录
    • 关于 Electron
    • Electron 版本说明
    • API弃用说明
    • 快速入门
    • 支持的平台
    • 桌面环境集成
    • 系统通知
    • 离屏渲染
    • 在线/离线事件检测
    • 多线程
    • REPL
    • 键盘快捷键
    • DevTools扩展
    • 使用原生模块
    • 使用 Pepper Flash 插件
    • 使用 Selenium 和 WebDriver
    • 使用 Widevine CDM 插件
    • 应用分发
    • 应用打包
    • 主进程调试
    • 使用 node-inspector 进行主进程调试
    • 使用 VSCode 进行主进程调试
    • Mac App Store应用提交指南
    • Windows App Store应用提交指南
    • 安全,本地功能和你的责任
    • Headless CI Systems 测试
  • API接口目录
    • API接口之公用接口
      • 应用语言
      • 开发概要
      • 专业术语
      • 常见问题
      • 环境变量
      • 快捷键字符串
      • 命令行
      • 客户端请求
      • 剪贴板
      • <File> H5 File文件操作
      • 无框窗口
      • <window.open> window.open打开新窗口或打开时传递消息
      • 沙盒选项
    • API接口之主进程接口
      • 整体控制
      • 全局快捷键
      • 图标创建与应用
      • 屏幕
      • 窗口
      • 菜单
      • 菜单项
      • 系统托盘
      • 网页内容
      • 从主进程到渲染进程的异步通信
      • 对话框
      • 创建和控制视图
      • 会话
      • 会话,缓存和代理等控制
      • 页面请求
      • HTTP/HTTPS请求处理
      • 协议的注册和处理
      • 使用系统默认应用程序管理文件或URL
      • 下载项管理
      • 进程控制
      • Chromium原生网络库
      • 获取系统首选项
      • 电源状态
      • 节能管理
      • 调试工具
      • 奔溃报告
      • 性能数据收集
      • 自动更新
      • TouchBar触摸条
      • TouchBar触摸条按钮
      • TouchBar触摸条拾色器
      • TouchBar触摸条分组
      • TouchBar触摸条scrubber
      • TouchBar触摸条分段控件
      • TouchBar触摸条label标签
      • TouchBar触摸条弹出框
      • TouchBar触摸条滑块
      • TouchBar触摸条间隔符
    • API接口之渲染进程接口
      • 页面渲染
      • <webview> webview标签
      • 渲染进程与主进程通信
      • 从渲染进程到主进程的异步通信
      • 子窗口
      • 捕获桌面资源
  • 结构列表
    • 蓝牙设备对象
    • 证书对象
    • 证书主体对象
    • Cookie对象
    • 崩溃报告对象
    • 桌面捕获源对象
    • 显示器对象
    • 打印机信息对象
    • 文件过滤器对象
    • 最近使用的项目
    • 常用列表项
    • CPU使用率对象即程序占用的CPU资源
    • IO值对象
    • 内存信息对象
    • 进程内存信息对象
    • 内存使用详细信息
    • Mime类型缓冲区
    • 矩形对象
    • 删除客户端证书对象
    • 删除密码对象
    • Scrubber项对象
    • 分段控制对象
    • 快捷方式对象
    • 任务对象
    • 缩略图工具栏按钮对象
    • 上传blob对象
    • 上传数据对象
    • 上传文件系统对象
    • 上传文件对象
    • 上传原始数据对象
Powered by GitBook
On this page
  • 平台相关的提示
  • macOS
  • Windows
  • Linux
  • 事件列表
  • 事件:'error'
  • 事件:'checking-for-update'
  • 事件:'update-available'
  • 事件:'update-not-available'
  • 事件:'update-downloaded'
  • 方法列表
  • autoUpdater.setFeedURL(url)
  • autoUpdater.getFeedURL()
  • autoUpdater.checkForUpdates()
  • autoUpdater.quitAndInstall()

Was this helpful?

  1. API接口目录
  2. API接口之主进程接口

自动更新

Previous性能数据收集NextTouchBar触摸条

Last updated 4 years ago

Was this helpful?

autoUpdater模块为框架提供了一个接口。

进程:

您可以使用这些项目之一进行快速启动多平台发布服务器以分发应用程序:

  • :为您的应用程序使用智能版本服务器,使用GitHub作为后端。使用Squirrel(Mac和Windows)自动更新

  • :功能齐全,自主托管的electron应用程序的发布服务器,兼容自动更新器

  • :简单的node.js服务器为Squirrel.Mac和Squirrel.Windows使用GitHub版本

  • [squirrel-release-server][squirrel-release-server]:简单的Squirrel.Windows的PHP应用程序,它从文件夹读取更新。支持增量更新。

平台相关的提示

虽然 autoUpdater 模块提供了一套各平台通用的接口,但是在每个平台间依然会有一些微小的差异。

macOS

在macOS上,autoUpdater模块建立在上,这意味着你不需要任何特殊的设置来使它工作。

对于服务器端要求,您可以阅读 .

注意(ATS)适用于所有请求作为更新过程的一部分。

如需禁用ATS的应用程序可以在其应用程序的plist中添加 NSAllowsArbitraryLoads键。

注意:您的应用程序必须在macOS上进行自动更新。这是的要求。

Windows

您应确保程序具有 app.setAppUserModelId API且ID相同,否则Windows将无法在应用程式的工作列中正确匹配您的应用程序。

Linux

在Linux上没有自动更新器的内置支持,因此建议使用分发包的包管理器来更新您的应用程序。

事件列表

autoUpdater 对象会触发以下的事件:

事件:'error'

触发:更新发生错误时

  • error Error

事件:'checking-for-update'

触发:开始检查更新时

事件:'update-available'

触发:发现一个可用更新时

事件:'update-not-available'

触发:没有可用更新时

事件:'update-downloaded'

触发:更新下载完成时

  • event Event

  • releaseNotes String - 新版本更新公告

  • releaseName String - 新的版本号

  • releaseDate Date - 新版本发布的日期

  • updateURL String - 更新地址

在 Windows 上只有 releaseName 是有效的。

方法列表

autoUpdater 对象有以下的方法:

autoUpdater.setFeedURL(url)

用途:设置 url并初始化自动更新器

  • url String

  • requestHeaders Object macOS (可选) - HTTP请求标头.

autoUpdater.getFeedURL()

用途:获得当前更新的Feed链接

返回 String

autoUpdater.checkForUpdates()

用途:询问服务器是否有更新

在调用这个方法之前,必须要先调用 setFeedURL。

autoUpdater.quitAndInstall()

用途:重新启动应用程序,并在更新已下载后安装

该方法只有在 update-downloaded被释放后才被调用。

注意项: autoUpdater.quitAndInstall()和普通退出有所区别,它将先关闭所有应用程序窗口,然后在 app上发出 before-quit事件。

在 Windows 上,你必须使用安装程序将你的应用装到用户的计算机上,所以比较推荐的方法是用 , 或 模块来生成Windows安装程序。

当使用或, 时,确保你不要尝试更新你的应用程序(另见)。还建议使用获取应用程序的桌面快捷方式。

使用Squirrel生成的安装程序将以 com.squirrel.PACKAGE_ID.YOUR_EXE_WITHOUT_DOT_EXE的格式创建一个带有的快捷图标,例子是 com.squirrel.slack.Slack'和com.squirrel.code.Code`。

服务器端设置也不同于macOS。您可以阅读的文档以获得更多详细信息。

[squirrel-release-server]:

electron-winstaller
electron-builder
grunt-electron-installer
electron-winstaller
electron-winstaller
electron-builder
第一次运行
这个问题的更多信息
electron-squirrel-startup
Application User Model ID
Squirrel.Windows
https://github.com/Arcath/squirrel-release-server
Squirrel
nuts
electron-release-server
squirrel-updates-server
Squirrel.Mac
Server Support
App传输安全
Squirrel.Mac
主进程