error:0308010C:digital envelope routines::unsupported
- 
- 报错原因
- 解决方案
- 
- 方案一:降低node版本在17以下
- 
- [指定node版本 mac node版本降级 mac切换node版本](#指定node版本 mac node版本降级 mac切换node版本)
 
- [方案二:启用legacy OpenSSL provider](#方案二:启用legacy OpenSSL provider)
- 方案三:配置package.json文件
- 拓展:package.json中的&&和&
 
 
报错原因
error:0308010C:digital envelope routines::unsupported
出现这个错误是因为 node.js V17版本中最近发布的OpenSSL3.0, 而OpenSSL3.0对允许算法和密钥大小增加了严格的限制,可能会对生态系统造成一些影响.
在node.js V17以前一些可以正常运行的的应用程序,但是在 V17 版本可能会抛出以下异常:
            
            
              javascript
              
              
            
          
          node:internal/crypto/hash:67
  this[kHandle] = new _Hash(algorithm, xofLen);
                  ^
Error: error:0308010C:digital envelope routines::unsupported
    at new Hash (node:internal/crypto/hash:67:19)
    at Object.createHash (node:crypto:130:10)
    at module.exports.__webpack_modules__.57442.module.exports (/Users/workspace/React/umiapp/node_modules/@umijs/deps/compiled/webpack/4/bundle4.js:135907:62)
    at NormalModule._initBuildHash (/Users/workspace/React/umiapp/node_modules/@umijs/deps/compiled/webpack/4/bundle4.js:109317:16)
    at handleParseError (/Users/workspace/React/umiapp/node_modules/@umijs/deps/compiled/webpack/4/bundle4.js:109371:10)
    at /Users/workspace/React/umiapp/node_modules/@umijs/deps/compiled/webpack/4/bundle4.js:109403:5
    at /Users/workspace/React/umiapp/node_modules/@umijs/deps/compiled/webpack/4/bundle4.js:109258:12
    at /Users/workspace/React/umiapp/node_modules/@umijs/deps/compiled/webpack/4/bundle4.js:61157:3
    at iterateNormalLoaders (/Users/workspace/React/umiapp/node_modules/@umijs/deps/compiled/webpack/4/bundle4.js:60998:10)
    at Array.<anonymous> (/Users/workspace/React/umiapp/node_modules/@umijs/deps/compiled/webpack/4/bundle4.js:60989:4) {
  opensslErrorStack: [ 'error:03000086:digital envelope routines::initialization error' ],
  library: 'digital envelope routines',
  reason: 'unsupported',
  code: 'ERR_OSSL_EVP_UNSUPPORTED'
}
Node.js v17.0.1
✨  Done in 1.92s.解决方案
方案一:降低node版本在17以下
看了一下错误堆栈,发现是一个Node的内核文件抛出来的错误,这个错误应该是和Node的版本有关(前几天刚刚升级过Node),降低Node的版本应该可以解决这个问题。或者使用nvm(Windows平台上也可以使用nvm-windows)安装多个不同的Node版本。
指定node版本 mac node版本降级 mac切换node版本
参考链接:https://blog.csdn.net/weixin_43770430/article/details/132420638
第一步 进行nvm 安装操作
            
            
              javascript
              
              
            
          
          brew install nvm 执行 nvm --version
            
            
              javascript
              
              
            
          
          nvm --version 
            
            
              javascript
              
              
            
          
          出现zsh: command not found: nvm问题去进行配置第二步 nvm配置
1.输入: vim ~/.bash_profile
点击 i 进行插入操作 插入下面配置
            
            
              javascript
              
              
            
          
          export NVM_DIR=~/.nvm
source $(brew --prefix nvm)/nvm.sh插入完成后 点击Esc 然后 使用 :wq. 保存并退出
执行:
            
            
              javascript
              
              
            
          
          source ~/.bash_profile如果出问题先不管接着往下走
2.输入:vim ~/.zshrc
点击 i 进行插入操作 插入下面配置
            
            
              javascript
              
              
            
          
          export NVM_DIR=~/.nvm
source $(brew --prefix nvm)/nvm.sh插入完成后 点击Esc 然后 使用 :wq. 保存并退出
执行:
            
            
              javascript
              
              
            
          
          source ~/.zshrc3.输入: vim ~/.profile
点击 i 进行插入操作 插入下面配置
            
            
              javascript
              
              
            
          
          export NVM_DIR=~/.nvm
source $(brew --prefix nvm)/nvm.sh插入完成后 点击Esc 然后 使用 :wq. 保存并退出
执行:
            
            
              javascript
              
              
            
          
          source ~/.profile- 最后开始进行测试
 执行:
            
            
              javascript
              
              
            
          
          nvm --version显示版本号就说明配置成功:0.39.1
第三步 安装node指定版本 node版本降级
执行:
            
            
              javascript
              
              
            
          
          nvm install v14.16.1安装完成后检查
            
            
              javascript
              
              
            
          
          node --version注意!!:
- 如果iterm2 中进行brew isntall xxx 或者brew update ,brew doctor 出现 fatal: not in a git directory报错提示时
            
            
              javascript
              
              
            
          
          fatal: not in a git director
No remote 'origin' in /usr/local/Homebrew/Library/Taps/homebrew/homebrew-ser解决方法
            
            
              javascript
              
              
            
          
           git config --global --add safe.directory /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core
	
git config --global --add safe.directory /usr/local/Homebrew/Library/Taps/homebrew/homebrew-services
	
git config --global --add safe.directory /usr/local/Homebrew/Library/Taps/homebrew/homebrew-caskgit 	- mac 系统终端node版本跟vscode终端node版本不一致时
 在vscode终端上执行这行代码,关闭vscode,重启就可以了。
            
            
              javascript
              
              
            
          
          nsudo rm -rf /usr/local/{lib/node{,/.npm,_modules},bin,share/man}/{npm*,node*,man1/node*}方案二:启用legacy OpenSSL provider
除了切换Node的版本来解决这个问题外,其实还可以尝试启用legacy OpenSSL provider来解决这个问题,通过下面的命令行操作起来更容易:
Unix (Linux, macOS, Git bash等)
            
            
              javascript
              
              
            
          
          export NODE_OPTIONS=--openssl-legacy-providerWindows
            
            
              javascript
              
              
            
          
          set NODE_OPTIONS=--openssl-legacy-providerPowerShell
            
            
              javascript
              
              
            
          
          $env:NODE_OPTIONS = "--openssl-legacy-provider"方案三:配置package.json文件
另外一个方法是在项目的package.json文件里将
            
            
              javascript
              
              
            
          
          "start": "react-scripts start"Windows
替换成:
            
            
              javascript
              
              
            
          
          "start": "react-scripts --openssl-legacy-provider start"mac
替换成:
            
            
              javascript
              
              
            
          
          "start": "export NODE_OPTIONS=--openssl-legacy-provider &&  react-scripts start"亲测有效
拓展:package.json中的&&和&
原文链接:https://blog.csdn.net/weixin_56361614/article/details/134010076
在 package.json 文件中的 scripts 字段中,一条命令可以同时执行多个指令。
而指令间可以使用
- &,例如:"start": "node app.js & nodemon"
- &&,例如:"start": "node app.js && nodemon"
- 不使用连接符,例如:"start": "node app.js nodemon"
三者区别:
一、&
& 符号:表示执行当前指令后立即执行下一个指令,不管上一个指令是否执行成功。
            
            
              javascript
              
              
            
          
          "scripts": {
  "start": "node app.js & nodemon"
}当执行 npm run start 命令时,会先执行 node app.js 指令,然后立即执行 nodemon 指令,不管 node app.js 是否执行成功。
二、&&
&& 符号:表示只有上一个指令执行成功后,才会执行下一个指令。
            
            
              javascript
              
              
            
          
          "scripts": {
  "start": "node app.js && nodemon"
}当执行 npm run start 命令时,会先执行 node app.js 指令,如果执行成功,则会执行 nodemon 指令;如果执行失败,则不会执行 nodemon 指令。
三、不使用连接符
如果在 package.json 文件中的 scripts 字段中不使用 & 和 && 符号来连接指令,那么默认情况下会按照顺序依次执行每个指令。
            
            
              javascript
              
              
            
          
          "scripts": {
  "start": "node app.js nodemon"
}当执行 npm run start 命令时,会先执行 node app.js 指令,然后执行 nodemon 指令。这里的 nodemon 实际上会作为 node app.js 的参数传递给它。
需要注意的是,如果某个指令执行失败(即返回非零的退出码),那么后续的指令将不会执行。因此,如果希望所有指令都能执行,可以使用 && 符号来连接它们,以确保前一个指令成功执行后才会执行下一个指令。