当前位置:   article > 正文

VUE解决Error: error:0308010C:digital envelope routines::unsupported的四种解决方案_vue error: error:0308010c:digital envelope routine

vue error: error:0308010c:digital envelope routines::unsupported

问题描述:
        报错:Error: error:0308010C:digital envelope routines::unsupported

报错原因:
        主要是因为 nodeJs V17 版本发布了 OpenSSL3.0 对算法和秘钥大小增加了更为严格的限制,nodeJs v17 之前版本没影响,但 V17 和之后版本会出现这个错误。 我的node版本是v18+

报错详细信息:

  1. rror: error:0308010C:digital envelope routines::unsupported
  2. at new Hash (node:internal/crypto/hash:71:19)
  3. at Object.createHash (node:crypto:133:10)
  4. at module.exports (D:\XXX\map-edit2\font\node_modules\webpack\lib\util\createHash.js:135:53)
  5. at NormalModule._initBuildHash (D:\XXX\map-edit2\font\node_modules\webpack\lib\NormalModule.js:417:16)
  6. at handleParseError (D:\XXX\map-edit2\font\node_modules\webpack\lib\NormalModule.js:471:10)
  7. at D:\XXX\map-edit2\font\node_modules\webpack\lib\NormalModule.js:503:5
  8. at D:\XXX\map-edit2\font\node_modules\webpack\lib\NormalModule.js:358:12
  9. at D:\XXX\map-edit2\font\node_modules\loader-runner\lib\LoaderRunner.js:373:3
  10. at iterateNormalLoaders (D:\XXX\map-edit2\font\node_modules\loader-runner\lib\LoaderRunner.js:214:10)
  11. at iterateNormalLoaders (D:\XXX\map-edit2\font\node_modules\loader-runner\lib\LoaderRunner.js:221:10)
  12. at D:\XXX\map-edit2\font\node_modules\loader-runner\lib\LoaderRunner.js:236:3
  13. at runSyncOrAsync (D:\XXX\map-edit2\font\node_modules\loader-runner\lib\LoaderRunner.js:130:11)
  14. at iterateNormalLoaders (D:\XXX\map-edit2\font\node_modules\loader-runner\lib\LoaderRunner.js:232:2)
  15. at Array.<anonymous> (D:\XXX\map-edit2\font\node_modules\loader-runner\lib\LoaderRunner.js:205:4)
  16. at Storage.finished (D:\XXX\map-edit2\font\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:55:16)
  17. at D:\XXX\map-edit2\font\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:91:9
  18. node:internal/crypto/hash:71
  19. this[kHandle] = new _Hash(algorithm, xofLen);
  20. ^
  21. Error: error:0308010C:digital envelope routines::unsupported
  22. at module.exports (D:\XXX\map-edit2\font\node_modules\webpack\lib\util\createHash.js:135:53)
  23. at NormalModule._initBuildHash (D:\XXX\map-edit2\font\node_modules\webpack\lib\NormalModule.js:417:16)
  24. at handleParseError (D:\XXX\map-edit2\font\node_modules\webpack\lib\NormalModule.js:471:10)
  25. at D:\XXX\map-edit2\font\node_modules\webpack\lib\NormalModule.js:503:5
  26. at D:\XXX\map-edit2\font\node_modules\webpack\lib\NormalModule.js:358:12
  27. at D:\XXX\map-edit2\font\node_modules\loader-runner\lib\LoaderRunner.js:373:3
  28. at iterateNormalLoaders (D:\XXX\map-edit2\font\node_modules\loader-runner\lib\LoaderRunner.js:214:10)
  29. at Array.<anonymous> (D:\XXX\map-edit2\font\node_modules\loader-runner\lib\LoaderRunner.js:205:4)
  30. at Storage.finished (D:\XXX\map-edit2\font\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:55:16)
  31. at D:\XXX\map-edit2\font\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:91:9
  32. at D:\XXX\map-edit2\font\node_modules\graceful-fs\graceful-fs.js:123:16
  33. at FSReqCallback.readFileAfterClose [as oncomplete] (node:internal/fs/read_file_context:68:3) {
  34. opensslErrorStack: [ 'error:03000086:digital envelope routines::initialization error' ],
  35. library: 'digital envelope routines',
  36. reason: 'unsupported',
  37. code: 'ERR_OSSL_EVP_UNSUPPORTED'
  38. }
  39. Node.js v18.12.1

解决方案: 
方案1:打开IDEA 终端,直接输入

Linux & Mac OS:

export NODE_OPTIONS=--openssl-legacy-provider
Windows:

set NODE_OPTIONS=--openssl-legacy-provider
方案2:打开IDEA 终端,直接输入(问题解决)
$env:NODE_OPTIONS="--openssl-legacy-provider"

 方案3:卸载当前版本,安装合适的版本(node.js)

方案4:

解决方式(仅限 windows):

在项目中 package.json 的 scripts 中新增 SET NODE_OPTIONS=--openssl-legacy-provider

添加前:

  1. "scripts": {
  2. "dev": "vue-cli-service serve",
  3. "build:prod": "vue-cli-service build"
  4. },

添加后:

  1. "scripts": {
  2. "dev": "SET NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service serve",
  3. "build:prod": "SET NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service build"
  4. },

笔者本人是采用第四种方案解决的,大家可以试试,希望可以帮到大家。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小舞很执着/article/detail/797905
推荐阅读
相关标签
  

闽ICP备14008679号