解决升级openssl到3.0以后,vue项目报错Error: error:0308010C:digital envelope routines::unsupported

解决升级openssl到3.0以后,vue项目报错Error: error:0308010C:digital envelope routines::unsupported

  • 问题原因
    • 解决办法
    • electron 项目解决办法

问题原因

这两天发现vue项目运行的时候报错了,错误如下:


  this[kHandle] = new _Hash(algorithm, xofLen);
                  ^

Error: error:0308010C:digital envelope routines::unsupported

通过查询资料发现跟openssl 3.0有关,检查了下升级记录,我用的 是Manjaro,升级记录如下:
软件包管理器的–查看历史记录: 2022-11-15T09:20:53+0800] [ALPM] upgraded openssl (1.1.1.q-1 -> 3.0.7-2)

解决办法

运行命令(run serve)的Node options 增加参数 --openssl-legacy-provider
解决升级openssl到3.0以后,vue项目报错Error: error:0308010C:digital envelope routines::unsupported_第1张图片
这样就能行了。

另外一种解决办法是 修改环境变量 ,/etc/profile 增加 export NODE_OPTIONS=–openssl-legacy-provider 这个不推荐,要重启系统才有效,而且虽然能解决 run serve问题,但是不能 解决打包问题。同时运行node时候会报错。

electron 项目解决办法

参考:https://github.com/nklayman/vue-cli-plugin-electron-builder/issues/1574

解决办法1是针对打包的,2是针对开发调试运行的。两个都要执行。

  1. electron:build_linux_arm(aarch) 打包。需要添加Node options参数如下:
    –openssl-legacy-provider

  2. electron:serve 运行。直接修改node_modules里面的代码。

// /purchase-evalbid-tool/node_modules/webpack/lib/util/createHash.js:135:53
switch (algorithm) {
  // TODO add non-cryptographic algorithm here
  case "debug":
    return new DebugHash();
  default:
    // return new BulkUpdateDecorator(require("crypto").createHash(algorithm));
    // bugfix 修复升级openssl3以后,报错问题:      
    return new BulkUpdateDecorator(require("crypto").createHash("sha1"));
}

你可能感兴趣的:(vue.js,前端,openssl3,0308010C)