解决electron-builder制作的安装包在安装过程中出现“安装中止”的问题

  1. 删除残留的注册表信息。这种方法比较繁琐,但是可以解决问题。在安装新版本之前,你需要删除之前安装的版本所残留的注册表信息。
  2. 修改打包配置文件中的appid 但是如果appid是固定的 则不能使用这个方案
    这是我项目的打包配置
javascript 复制代码
electron-builder.json
{
  "productName": "name",
  "appId": "appId",
  "directories": {
    "output": "release/v${version}"
  },
  "files": [
    "dist-electron",
    "dist"
  ],
  "publish": [
    {
      "provider": "generic",
      "url": ""
    }
  ],
  "asar": true,
  "nsis": {
    "oneClick": false,
    "perMachine": true,
    "shortcutName": "${productName}",
    "uninstallDisplayName": "${productName}",
    "runAfterFinish": true,
    "deleteAppDataOnUninstall": true,
    "allowToChangeInstallationDirectory": true,
    "include": "dist/installer.nsh",
    "guid": "b96a0cd0-6202-4088-9981-15fdd925595c"
  },
  "win": {
    "icon": "dist/favicon.ico",
    "artifactName": "${productName}.${ext}",
    "requestedExecutionLevel": "requireAdministrator"
  },
  "mac": {
    "icon": "dist/favicon.icns",
    "artifactName": "${productName}_${version}.${ext}",
    "target": [
      "dmg"
    ]
  },
  "linux": {
    "target": [
      "AppImage",
      "deb"
    ],
    "icon": "dist/favicon.ico",
    "artifactName": "${productName}.${ext}",
    "desktop": {
      "Icon": "/opt/electron-pure-admin/resources/app/dist/favicon.ico"
    }
  }
}
  1. 通过修改nsis中guid来达到要求 guid是有规则的 不能随便填写 这个方法更灵活些 不需要每次打包的时候都修改代码 只需要进行相应配置即可
  • 首先需要新建一个generate-guid.js文件用来每次打包的时候生成一个新的guid
javascript 复制代码
function guid() { // 这是在网上找的guid生成算法
  return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function (c) {
    const r = (Math.random() * 16) | 0,
      v = c == "x" ? r : (r & 0x3) | 0x8;
    return v.toString(16);
  });
}

const fs = require("fs");

// 生成新的GUID
const newGuid = guid();

// 读取package.json文件
const electronJson = JSON.parse(fs.readFileSync("electron-builder.json"));

// 将新的GUID写入package.json文件
electronJson.nsis.guid = newGuid;
fs.writeFileSync(
  "electron-builder.json",
  JSON.stringify(electronJson, null, 2)
);
  • 其次在package.json中添加一行预打包配置代码来执行generate-guid.js文件
json 复制代码
	"prebuild": "node ./generate-guid.js"
  • 然后运行npm run build就可以啦

知识点:

  1. nsis中的guid指的是什么

在 Electron 的 NSIS 安装程序中,GUID 是全局唯一标识符的缩写,它是一个 128 位长的数字和字母组合的字符串,用于标识软件应用程序或安装程序包的唯一性。'

当你在 Electron 应用中使用 GUID 时,它是用来确保你的应用或安装程序的每个版本都具有唯一的标识符。这样可以避免重复安装或者覆盖安装的问题,从而确保用户在安装新的 Electron 应用版本时不会丢失之前的数据。

  1. nsis的guid可以随意赋值吗

不可以 如果你随意赋值,可能会导致安装程序出现错误或冲突,例如覆盖安装而不是更新应用程序,或者无法正确识别已安装的应用程序版本

  1. npm run xxx的执行顺序

npm脚本有pre和post两个钩子,例如执行npm run build的时候,会自动按照下面的顺序执行:npm run prebuild&& npm run build&& npm run postbuild。通过定义prebuild或postbuild所对应的脚本,就可以让它们在build命令的前后执行2。

相关推荐
J不A秃V头A33 分钟前
Vue3:编写一个插件(进阶)
前端·vue.js
司篂篂1 小时前
axios二次封装
前端·javascript·vue.js
姚*鸿的博客1 小时前
pinia在vue3中的使用
前端·javascript·vue.js
宇文仲竹2 小时前
edge 插件 iframe 读取
前端·edge
Kika写代码2 小时前
【基于轻量型架构的WEB开发】【章节作业】
前端·oracle·架构
天下无贼!3 小时前
2024年最新版Vue3学习笔记
前端·vue.js·笔记·学习·vue
Jiaberrr3 小时前
JS实现树形结构数据中特定节点及其子节点显示属性设置的技巧(可用于树形节点过滤筛选)
前端·javascript·tree·树形·过滤筛选
赵啸林3 小时前
npm发布插件超级简单版
前端·npm·node.js
我码玄黄4 小时前
THREE.js:网页上的3D世界构建者
开发语言·javascript·3d
罔闻_spider4 小时前
爬虫----webpack
前端·爬虫·webpack