以下是使用 autoUpdater 模块的基本步骤:
1. 在主进程中引入 autoUpdater 模块:
const { app, autoUpdater } = require('electron');
2. 配置更新源:
在应用程序初始化时,设置更新源的 URL,通常是包含更新信息的服务器地址。
const feedUrl = 'https://your-update-server.com';
autoUpdater.setFeedURL(feedUrl);
确保替换 https://your-update-server.com 为实际的更新服务器地址。
3. 监听更新事件:
监听 autoUpdater 的一些事件,以便在更新过程中执行相应的操作。
autoUpdater.on('checking-for-update', () => {
console.log('Checking for update...');
});
autoUpdater.on('update-available', (info) => {
console.log('Update available:', info);
});
autoUpdater.on('update-not-available', () => {
console.log('Update not available.');
});
autoUpdater.on('update-downloaded', (info) => {
console.log('Update downloaded:', info);
});
autoUpdater.on('error', (err) => {
console.error('Error in auto-updater:', err);
});
4. 触发检查更新:
在应用程序启动时触发检查更新的操作。
app.whenReady().then(() => {
autoUpdater.checkForUpdatesAndNotify();
});
checkForUpdatesAndNotify 方法会自动检查更新,如果有新版本,则会下载并通知用户。
5. 打包应用程序时添加自动更新相关信息:
在使用打包工具(如 electron-builder)打包应用程序时,确保在配置文件中包含自动更新相关的信息,如 package.json 文件中的 build 配置。
"build": {
"publish": [
{
"provider": "github",
"owner": "your-github-username",
"repo": "your-repo-name"
}
]
}
上述示例中使用了 GitHub 作为更新源,你需要替换 "your-github-username" 和 "your-repo-name" 为你的 GitHub 用户名和仓库名。
6. 处理自动更新的渲染进程通知:
如果你希望在渲染进程中处理更新通知,你可以使用 IPC 通信,将主进程的更新信息传递给渲染进程。
// 在主进程中
autoUpdater.on('update-downloaded', (info) => {
mainWindow.webContents.send('update-downloaded', info);
});
// 在渲染进程中
const { ipcRenderer } = require('electron');
ipcRenderer.on('update-downloaded', (event, info) => {
// 处理更新下载完成的通知
});
以上步骤是一个简单的自动更新的流程。在实际应用中,你可能需要考虑更多的细节,如处理更新的用户界面、自定义更新通知、检查更新的定时任务等。详细的信息可以在 Electron 官方文档的 [autoUpdater 部分](https://www.electronjs.org/docs/api/auto-updater) 找到。
转载请注明出处:http://www.pingtaimeng.com/article/detail/10916/Electron