大部分教學都不太一樣,後來發現 Electron-builder 的 Autodater 跟 Electron 的 Autoupdater 不太一樣。Electron 內建必須做 codesign 簽章,但不知道能不能用 mkcert ,但感覺不太能做的樣子。avast 一直對我build 出來 msi,exe 做掃描,聽說 codesign 能改善這個問題? codesign 感覺也是大坑,這篇先主要把我網路上整理資料先為主,先以 electron-builder為主。
相關爬的文章整理
avocode/electron-windows-autoupdate: Get Electron AutoUpdater working on Windows
Electron應用使用electron-builder配合electron-updater實現自動更新 - SegmentFault 思否
注意:這個autoUpdater不是electron中的autoUpdater,是electron-updater的autoUpdater,否則坑你沒商量!
[ Day 35 ] - Electron 應用程式 - 更新自動化 ( 說明篇 ) - iT 邦幫忙::一起幫忙解決難題,拯救 IT 人的一天
electron-builder-auto-update-example/src at master · alondanoch/electron-builder-auto-update-example
electron-autoupdate-scaffold/README.md at master · ganyouyin/electron-autoupdate-scaffold
[ Day 35 ] - Electron 應用程式 - 更新自動化 ( 說明篇 ) - iT 邦幫忙::一起幫忙解決難題,拯救 IT 人的一天
electron-builder autoupdater 一般更新
非常推薦看Electron自动更新 - 王叨叨(備份圖)這篇,裡面有詳細介紹各種寫法,還有demo。
使用 electron-builder 及 electron-updater 给项目配置自动更新_一片天空-CSDN博客
electron-updater更新electron应用程序 - 簡書
裡面還有提到electron-log日志,不知道有沒有機會使用到???
這邊就直接用第一篇文章範例直接操作。
git clone wangdaodao/vue-electron-template 下來,裡面都已經設定好。
調整項目
- vue.config.js 更新網址改成本機 IP 就可以更新。
- dist_electron 改成 download HFS 更新,這邊你可以用其他 HTTP Server 都可以。
Github更新 Electron 程式
更新官方有幾種方式,有支援AWS空間,其中讓我感興趣是 github 。私有的專案也可以用的,但不知道會不會有什麼限制。文件有提到可以用 Github Actions 發布,我突然想到我的malagege/vue-electron-Pomodoro參考cawa-93/vite-electron-builder: Secure boilerplate for Electron app based on Vite. TypeScript + Vue/React/Angular/Svelte/Vanilla專案做的,裡面有設定 Github Actions。看文章說執行完會在 Github Release 建立草稿,我看之前專案有 build 成功過。
我看Release真的有建立。
題外話,這邊發現我Github Actions 後面都錯誤,但大概猜到是因為使用 desktop-idle 關係造成的,最後有排除。github actions 失敗問題 · malagege/vue-electron-Pomodoro@e3ffacf
最後排除掉,就是設定 provide 設定成 Github,其它要設定什麼,當出我也很疑惑,我這邊卡很久再研究文件,最後發現 Github Actions 會帶 github token ,也會帶 Repo 名稱參數,所以只要設設定我怎麼沒先動手試試,這邊看了一段時間,哈哈。設定 provide 設定成 Github
。
我後來用沒設定前一版沒做 Github 設定,竟然會更新,太神奇了。可能 Action 那一段有做到更新。
electron.builder.config.js
打開舊版APP就會跳出更新就是成功了。這邊更新會等關掉程式後更新,還算滿人性化更新。另外,我參考原本程式就有做這段。
1 | // Auto-updates |
手動執行更新
Electron 十问十答(2) | Beace Blog
[electron]終極奧義 五千字教程丟給你 - IT閱讀
Electron应用实现自动更新 - 知乎
Electron Auto-Updater via Renderer (Frontend) Manipulation | by Meriç Melike Yılmaz | Medium
electron + nodejs (热更新)_这么近又那么远的博客-CSDN博客
大部分教學都沒有用 bridge 串,所以必須用 ipcmain 去接收是否要做更新。
了解 AutoUpdater 函式/事件
事件(Event)
error
中間發生錯誤觸發 error Event。
checking-for-update
更新開始後,馬上觸發這個 Event。
update-available
檢查到可以更新後,觸發這個 Event。如果autoDownload
設定 true
將會自動下載更新程式。
參數:
info UpdateInfo (for generic and github providers) | VersionInfo (for Bintray provider)
update-not-available
沒有檢查到更新,觸發這個 Event。
download-progress
下載時候觸發Event?
update-downloaded
下載完成觸發Event。
Method
checkForUpdates ⇒ Promise<UpdateCheckResult>
請求Server看是不是有更新。
checkForUpdatesAndNotify ⇒ Promise<UpdateCheckResult>
(重點)
請求Server看是不是有更新,有的畫自動更新和發送通知。
Call autoUpdater.checkForUpdatesAndNotify()
. Or, if you need custom behaviour, implement electron-updater
events, check examples below.
這邊特別說明一下,下面通知是寫死固定,原本看文件以為沒辦法調整,不過看源碼可以帶參數修正文字訊息。
1 | if (import.meta.env.PROD) { |
彩蛋錯誤
1 | ipcMain.on('check-update', function(){ |
vue CLI异步组件报错import’ and ‘export’ may only appear at the top level_郑伟斌的博客-CSDN博客
這篇有空再整理 import 用法(有時間的話,哈哈)
downloadUpdate
autoDownload = false
自動下載關閉,可以使用這個method下載。
getFeedURL
設定 update provider
quitAndInstall
appUpdater.quitAndInstall(isSilent, isForceRunAfter)
關閉程式並且更新。
1 | Restarts the app and installs the update after it has been downloaded. It should only be called after update-downloaded has been emitted. |
結論
本篇採用 electron-builder 簡單實作用 Github 手動/自動更新程式,這邊設定只是基本調整,其實還有滿多東西沒有整理出來,因為是簡單研究,所以就打算繼續深入,相信以後專案需要做單機版我就可以考慮採用這方案去進行。