当前位置: 首页 > news >正文

Electron 打包与分发

Electron 中的打包与分发

打包是将 Electron 应用从开发环境转换为可分发的独立桌面安装包的过程(Windows: .exe/.msi;macOS: .dmg/.app;Linux: .deb/.rpm/.AppImage)。官方推荐使用成熟的打包工具,避免手动操作。以下基于 2025 年最新实践总结。

1.主流打包工具对比
工具优点缺点/注意事项支持平台推荐场景
electron-builder配置最简单、功能最全(自动更新、代码签名、多种格式、多语言安装器)依赖较多,偶尔配置复杂Win/mac/Linux首选,大多数项目
electron-forge官方推荐,模块化(支持多种 maker),与 Webpack/Vite 集成好配置稍繁琐,自动更新需额外插件Win/mac/Linux喜欢模块化、需要自定义流程
electron-packager最轻量、简单快速只打包不生成安装器,需手动签名/公证Win/mac/Linux快速原型、内部分发
electron-updater + builder与 builder 结合实现自动更新--所有需要自动更新的应用

2025 年推荐electron-builder(社区最活跃,文档最全)。

2.使用 electron-builder 打包(推荐流程)

安装

npminstall--save-dev electron-builder

package.json 配置(关键部分):

{"name":"my-app","version":"1.0.0","main":"main.js","scripts":{"build":"electron-builder","dist:win":"electron-builder --win","dist:mac":"electron-builder --mac","dist:linux":"electron-builder --linux"},"build":{"appId":"com.example.myapp","productName":"MyApp","directories":{"output":"dist"// 输出目录},"files":["dist-electron/**/*",// Vite/Webpack 输出"main/**/*"],"win":{"target":[{"target":"nsis","arch":["x64","ia32"]},// 安装器{"target":"portable"}// 便携版],"icon":"build/icon.ico"},"mac":{"target":["dmg","zip"],"icon":"build/icon.icns","hardenedRuntime":true,"gatekeeperAssess":false,"entitlements":"build/entitlements.mac.plist"},"linux":{"target":["AppImage","deb","rpm"],"icon":"build/icons"},"nsis":{"oneClick":false,// 多语言安装器"allowToChangeInstallationDirectory":true}}}

常见打包命令

# 打包所有平台npmrun build# 只打包当前平台npmrun build -- --publish never# 发布(配合自动更新)npmrun build -- --publish always
3.代码签名与公证(必须,用于生产发布)
平台要求操作方式
WindowsSmartScreen 信任、病毒扫描使用 EV 代码签名证书(DigiCert、Sectigo)
CSC_LINKCSC_KEY_PASSWORD环境变量
macOSGatekeeper、Notarization(公证)必备- Apple Developer ID 证书
- 启用 Hardened Runtime
- electron-builder 自动公证(需APPLE_IDAPPLE_ID_PASSWORD
Linux无强制,但 AppImage 可签名可选 GPG 签名
4.自动更新(Squirrel / electron-updater)

推荐使用electron-updater(与 builder 无缝集成)。

配置

npminstallelectron-updater

主进程代码

const{autoUpdater}=require('electron-updater');autoUpdater.on('checking-for-update',()=>{/* ... */});autoUpdater.on('update-available',()=>{/* 提示用户 */});autoUpdater.on('update-downloaded',()=>{autoUpdater.quitAndInstall();});// 启动时检查app.whenReady().then(()=>{autoUpdater.checkForUpdatesAndNotify();});

发布服务器选项

builder 配置(package.json):

"publish":[{"provider":"github","owner":"yourname","repo":"my-app"}]
5.最佳实践与常见坑

使用 electron-builder + electron-updater + GitHub Releases 的组合,是当前最成熟、最省心的打包与分发方案。如果你的项目使用 Vite + React/Vue 或有特殊需求(如企业内部分发、自定义安装器),可以提供更多信息,我可以给出更精确的配置示例!

http://www.jsqmd.com/news/122549/

相关文章:

  • zabbix监控MinIO
  • 芯谷科技—D2503A高效降压型DC-DC转换器,助力电源设计新突破 - 详解
  • Electron 发布与部署
  • LangFlow上下文传递机制是如何工作的?
  • 2025考CISP国家注册信息安全认证,先看这篇!
  • 掌握这4种异常处理模式,轻松应对Open-AutoGLM解密崩溃危机
  • 2025年年终北京别墅装修公司推荐:专家聚焦设计、工艺与全案服务维度的5家优质企业选购指南 - 十大品牌推荐
  • Linux 进程通信:信号与共享内存详解
  • Electron 实战项目
  • LangFlow新闻摘要自动生成系统实战
  • 2025年年终北京别墅装修公司推荐:聚焦隐蔽工程与环保标准严苛评测,5家高口碑别墅专家深度解析 - 十大品牌推荐
  • Open-AutoGLM全局异常监听配置全攻略(避免线上事故的最后防线)
  • 2025 自动化运维产品深度对比:破解异构架构与合规高效双重挑战
  • 告别弹窗混乱时代,Open-AutoGLM实现自动化精准控制的4大秘诀
  • Open-AutoGLM异常处理全解析:5个必须掌握的解密容错策略
  • 2025年年终北京别墅装修公司推荐:基于多品牌深度横评与真实用户口碑的5家高可靠性服务商盘点 - 十大品牌推荐
  • LangFlow与主流大模型平台对比评测
  • Open-AutoGLM弹窗监控与自动关闭技术实践(独家方案首次公开)
  • 南京效果好质量优价格低全自动自清洗过滤器华博/博璟源优势解析 - 速递信息
  • 香港体育杰出领袖黑志宏领衔 沪港共筑海派武脉——绞龙棍激活香江青少年武术新生态
  • vxe-table 导入 excel xlsx 时,单元格内容值丢失前面0解决方法
  • 【紧急预警】Open-AutoGLM新版更新将加剧弹窗阻断,你做好准备了吗?
  • nanoid 全面教程:常用 API 串联与 Next.js 15 实战指南
  • 云迁移安全决胜之道:企业全业务上云的战略布局与风险防控指南
  • LangFlow异步执行支持情况说明
  • 1688商品详细信息价格SKU接口
  • nginx排查错误日志
  • 嵌入式第三十八篇——linux系统编程——IPC进程间通信
  • Vue3新特性实战:从入门到精通
  • springboot + vue