--openssl-legacy-provider is not allowed in NODE_OPTIONS 报错的处理方式

解决方案

  1. Node.js 应用

    • 从 Node.js v17+ 开始,底层升级到 OpenSSL 3.0,可能导致旧代码报错(如 ERR_OSSL_EVP_UNSUPPORTED)。

    • 通过以下命令启用旧算法支持:

      bash 复制代码
      node --openssl-legacy-provider your_script.js
  2. Vue应用

    • 从 Node.js v17+ 开始,底层升级到 OpenSSL 3.0,可能导致旧代码报错(如 ERR_OSSL_EVP_UNSUPPORTED)。

    • 通过以下命令启用旧算法支持:

      json 复制代码
      "scripts": {
          "serve": "set NODE_OPTIONS=--openssl-legacy-provider & vue-cli-service serve",
          "build": "set NODE_OPTIONS=--openssl-legacy-provider & vue-cli-service build",
          "lint": "vue-cli-service lint"
        },

背景知识

OpenSSL 3.0 引入了 Provider(提供者) 机制,将加密算法按功能分成了不同的模块:

  • 默认 Provider:包含符合现代安全标准的算法(如 SHA-2、AES 等)。
  • Legacy Provider:包含旧版或不推荐使用的算法(如 MD5、DES、RIPEMD 等)。
  • FIPS Provider:符合 FIPS 标准的算法。

出于安全考虑,OpenSSL 3.0 默认禁用了一些过时的算法。如果应用程序依赖这些旧算法,需显式启用 legacy provider


相关推荐
墨鸦_Cormorant8 小时前
Vue 概述以及基本使用
前端·javascript·vue.js
小吴-斌8 小时前
本地请求接口报SSL错误解决办法(Could not verify * SSL certificate)
网络·网络协议·ssl
懂得节能嘛.8 小时前
【动态配置中心】Java+Redis构建动态配置中心
java·开发语言·redis
专注于大数据技术栈8 小时前
Java中JDK、JRE、JVM概念
java·开发语言·jvm
JarvanMo8 小时前
10 个能帮你节省大量开发时间的低估 Flutter 组件
前端
去伪存真8 小时前
公司前端项目ESLint规则集统一化
前端
鹏多多8 小时前
使用imaskjs实现js表单输入卡号/日期/货币等掩码的教程
前端·javascript·vue.js
w2vmany8 小时前
postmessage xss初步学习
前端·学习·xss
波诺波8 小时前
通用装饰器示例
开发语言·python
沐知全栈开发8 小时前
Maven POM 简介
开发语言