1.报错
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| Error: error:0308010C:digital envelope routines::unsupported at new Hash (node:internal/crypto/hash:71:19) at Object.createHash (node:crypto:133:10) at module.exports (D:\class\fish\ruoyi-ui\node_modules\webpack\lib\util\createHash.js:135:53) at NormalModule._initBuildHash (D:\class\fish\ruoyi-ui\node_modules\webpack\lib\NormalModule.js:417:16) at handleParseError (D:\class\fish\ruoyi-ui\node_modules\webpack\lib\NormalModule.js:471:10) at D:\class\fish\ruoyi-ui\node_modules\webpack\lib\NormalModule.js:503:5 at D:\class\fish\ruoyi-ui\node_modules\webpack\lib\NormalModule.js:358:12 at D:\class\fish\ruoyi-ui\node_modules\loader-runner\lib\LoaderRunner.js:373:3 at iterateNormalLoaders (D:\class\fish\ruoyi-ui\node_modules\loader-runner\lib\LoaderRunner.js:214:10) at Storage.finished (D:\class\fish\ruoyi-ui\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:55:16) at D:\class\fish\ruoyi-ui\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:91:9 at D:\class\fish\ruoyi-ui\node_modules\graceful-fs\graceful-fs.js:123:16 at FSReqCallback.readFileAfterClose [as oncomplete] (node:internal/fs/read_file_context:68:3) { opensslErrorStack: [ 'error:03000086:digital envelope routines::initialization error' ], library: 'digital envelope routines', reason: 'unsupported', code: 'ERR_OSSL_EVP_UNSUPPORTED' }
Node.js v18.12.1
|
2.原因
因为 node.js V17版本中最近发布的OpenSSL3.0, 而OpenSSL3.0对允许算法和密钥大小增加了严格的限制,可能会对生态系统造成一些影响。故此以前的项目在升级 nodejs 版本后会报错。
3.解决
1.推荐:修改你要运行项目的package.json,在相关构建命令之前加入SET NODE_OPTIONS=–openssl-legacy-provider
1 2 3 4
| "scripts": { "serve": "SET NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service serve", "build": "SET NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service build" },
|
这种可以一劳永逸,以后直接通过npm执行scripts里面的命令即可。不管是项目迭代,还是团队开发,这种都比较有效。
2.当次运行的命令窗口有效:在你当前文件的cmd命令窗口输入:SET NODE_OPTIONS=–openssl-legacy-provider, 回车后输入 npm运行命令

这种做法,就是每次运行都要输入SET NODE_OPTIONS=–openssl-legacy-provider,来告诉nodejs,别使用最新的SSL3.0,还是使用以前旧版本的。
3.就是nodejs版本回退到16版本,这样就可以直接运行了。(这个最适合项目维护)
4.后话
关于:SET NODE_OPTIONS=–openssl-legacy-provider,其实这种方法不能一劳永逸,它的legacy的中文意思翻译过来是经典的,传统的,对于目前2022年12月4号来说,openssl3.0是最新的,之前的版本属于legacy版本,但是随着时间的推移,
未来可能在2024年,openssl3.0可能也变成了legacy版本,此时再设置SET NODE_OPTIONS=–openssl-legacy-provider,来通知nodejs使用传统的openSSL来执行,那么可能就会运行错误。那么对于产品的迭代维护来说,最好的话,还是使用旧版本的nodejs,比如16版本的,这个才可能是解决问题的关键。