运行下载的vue项目报错:Error: error:0308010C:digital envelope routines::unsupported
- 报错
- 报错原因
出现这个错误是因为 node.js V17版本中发布的OpenSSL3.0, 而OpenSSL3.0对允许算法和密钥大小增加了严格的限制,可能会对生态系统造成一些影响.在3.0版本中 md4不再被允许使用,在node 17版本之前使用 md4方法不会报错,但 v17之后将抛出一个 error code 为 ERR_OSSL_EVP_UNSUPPORTED 的错误信息。
这个问题导致了node.js V17以前一些可以正常运行的的应用程序,但是在 V17 版本可能会抛出这个异常。
- 解决方法
3.1降低nodejs版本
这个方法是最直接也是最麻烦的方法,尝试卸载Node.js 17+版本并重新安装Node.js 16一下的版本,然后再重新启动。
这个方法,测试有效,但我推荐的是第二个办法,第二个方法简实用。
3.2修改nodejs的默认参数
我们已经知道出现这个错误是因为 node.js V17+版本中发布的OpenSSL3.0导致node.js V17+运行某些项目出现0308010C错误。那么可以直接使用命令在程序执行前修改允许算法和密钥大小的参数即可。
那么我们在执行运行项目命令之前,先运行这个命令:
Linux & Mac OS:
export NODE_OPTIONS=--openssl-legacy-provider
windows命令提示符:
set NODE_OPTIONS=--openssl-legacy-provider
这个命令的作用就是告诉nodejs,别使用OpenSSL 3.0,还使用老版的 OpenSSL
这样就可以解决了,亲测有效。
但是是每次启动项目都要运行一下这个命令,所以,我们可以把它配置一下。
3.3修改配置文件,解决报错(推荐)
根据自己的系统类型,选择一个上面的命令
Windows:
set NODE_OPTIONS=--openssl-legacy-provider
Linux或Mac OS
export NODE_OPTIONS=--openssl-legacy-provider
然后,找到项目的package.json文件,把自己对应的命令,加上&&,写到启动项目的配置里面(构建写不写都可以),即可。
注意:set NODE_OPTIONS=--openssl-legacy-provider 一定要放到前面...