Vue项目运行开发服务时遇到的一个报错

使用yarn编译运行VuePress项目的开发环境时,遇到了一个报错,报错内容是这样的

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 (/root/vp/node_modules/webpack/lib/util/createHash.js:135:53)
    at NormalModule._initBuildHash (/root/vp/node_modules/webpack/lib/NormalModule.js:417:16)
    at handleParseError (/root/vp/node_modules/webpack/lib/NormalModule.js:471:10)
    at /root/vp/node_modules/webpack/lib/NormalModule.js:503:5
    at /root/vp/node_modules/webpack/lib/NormalModule.js:358:12
    at /root/vp/node_modules/loader-runner/lib/LoaderRunner.js:373:3
    at iterateNormalLoaders (/root/vp/node_modules/loader-runner/lib/LoaderRunner.js:214:10)
    at iterateNormalLoaders (/root/vp/node_modules/loader-runner/lib/LoaderRunner.js:221:10)
    at /root/vp/node_modules/loader-runner/lib/LoaderRunner.js:236:3
    at runSyncOrAsync (/root/vp/node_modules/loader-runner/lib/LoaderRunner.js:130:11)
    at iterateNormalLoaders (/root/vp/node_modules/loader-runner/lib/LoaderRunner.js:232:2)
    at Array.<anonymous> (/root/vp/node_modules/loader-runner/lib/LoaderRunner.js:205:4)
    at Storage.finished (/root/vp/node_modules/enhanced-resolve/lib/CachedInputFileSystem.js:55:16)
    at /root/vp/node_modules/enhanced-resolve/lib/CachedInputFileSystem.js:91:9
node:internal/crypto/hash:71
  this[kHandle] = new _Hash(algorithm, xofLen);
                  ^

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 (/root/vp/node_modules/webpack/lib/util/createHash.js:135:53)
    at NormalModule._initBuildHash (/root/vp/node_modules/webpack/lib/NormalModule.js:417:16)
    at handleParseError (/root/vp/node_modules/webpack/lib/NormalModule.js:471:10)
    at /root/vp/node_modules/webpack/lib/NormalModule.js:503:5
    at /root/vp/node_modules/webpack/lib/NormalModule.js:358:12
    at /root/vp/node_modules/loader-runner/lib/LoaderRunner.js:373:3
    at iterateNormalLoaders (/root/vp/node_modules/loader-runner/lib/LoaderRunner.js:214:10)
    at Array.<anonymous> (/root/vp/node_modules/loader-runner/lib/LoaderRunner.js:205:4)
    at Storage.finished (/root/vp/node_modules/enhanced-resolve/lib/CachedInputFileSystem.js:55:16)
    at /root/vp/node_modules/enhanced-resolve/lib/CachedInputFileSystem.js:91:9
    at /root/vp/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.16.1

解决方法

1. 更新node到新版>=16.

如果你的node版本已经大于等于16,则跳过该步骤

2. 开启OpenSSL支持.

On Unix-like (Linux, macOS, Git bash, etc.):

export NODE_OPTIONS=--openssl-legacy-provider

On Windows command prompt:

set NODE_OPTIONS=--openssl-legacy-provider

On PowerShell:

$env:NODE_OPTIONS = "--openssl-legacy-provider"
本文总阅读量