为什么运行时要加set NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service serve

为什么要加 NODE_OPTIONS=--openssl-legacy-provider

这不是 Vue 或 vue-cli-service 自己的参数,而是 传给 Node.js 的启动选项

  1. Node 17 起内置 OpenSSL 3.0

    和 OpenSSL 1.x 相比,3.0 默认关掉了一些旧算法(例如 Webpack 4 用来做模块标识/哈希时可能用到的 MD4 等)。

  2. 你这套栈还是 Webpack 4(Vue CLI 4)

    构建和开发服务器在跑 Webpack 时,会走到这些旧加密接口,在 OpenSSL 3.0 下就会报:
    error:0308010C:digital envelope routines::unsupported

  3. --openssl-legacy-provider 的作用

    让 Node 再加载 旧版算法提供程序 ,这样 Webpack 4 还能像以前一样用那些哈希/摘要,构建和 serve 才能正常跑完。

  4. 为什么要写在 NODE_OPTIONS 里?
    vue-cli-service serve 本质是 用 Node 去执行脚本 。把选项放在环境变量 NODE_OPTIONS 里,等于 每次启动 Node 都带上这个参数,不用改 Node 安装目录或全局配置。

  5. set ... && 是 Windows cmd 的写法

    只在当前 cmd 会话里设置环境变量,再执行后面的命令。PowerShell 要用 $env:NODE_OPTIONS=...,跨平台更稳妥的是用 cross-env(你项目里脚本已经可以这样写)。


总结: 加这一行不是为了"运行时特殊功能",而是为了 在较新的 Node 上兼容旧的 Webpack 4 加密用法 。长期做法是升级 Vue CLI 5 / Webpack 5,就可以不再依赖这个开关。

相关推荐
yqcoder12 小时前
CSS 迷思破解:`:nth-child` vs `:nth-of-type`
前端·css
时寒的笔记12 小时前
某陆飞11期_webpack案例
前端·webpack·node.js
漫游的渔夫13 小时前
前端开发者做多步 Agent:别让 AI 边想边乱跑,用 Plan-Act-Observe 稳住 4 步任务
前端·人工智能·typescript
武帝为此13 小时前
【Selenium 执行 JavaScript】
javascript·selenium·测试工具
一锤捌拾13 小时前
V8引擎精品漫游指南--Ignition篇(下 一) 动态执行前的事情
前端·javascript
遇见~未来13 小时前
第六篇_CSS进阶_深入浏览器与工程化
前端·css·rust
Cache技术分享13 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
前端·后端
Daybreak13 小时前
Vercel Serverless 调国内 AI 接口 504?Edge Runtime 救了我
前端
Elastic 中国社区官方博客13 小时前
用于 JavaScript 和 TypeScript 的 ES|QL 查询构建器:流式、类型安全的查询构建
大数据·javascript·数据库·elasticsearch·搜索引擎·typescript·全文检索
zubylon13 小时前
Ollama 本地起一个开发助手
前端·人工智能