当前位置: 首页 > news >正文

Joplin-解决 Node.js 中 “digital envelope routines::unsupported“ 错误

解决 Node.js 中 “digital envelope routines::unsupported” 错误

在使用 Webpack 构建 Joplin 插件时,你可能会遇到 error:0308010C:digital envelope routines::unsupported 错误。这个错误看起来很复杂,但实际上有明确的原因和解决方案。

错误原因分析

这个错误发生在 Node.js v17+ 版本中,根源是:

  • Node.js v17+ 升级到了 OpenSSL 3.0
  • OpenSSL 3.0 移除了一些不安全的加密算法(如 MD4)
  • 旧版本的 Webpack(如我们项目中使用的 4.46.0)仍在使用这些被移除的算法

当你运行 npm run dist 时,Webpack 尝试使用已被移除的加密算法,导致 Node.js 抛出此错误。

解决方案

方案 1:设置环境变量(推荐)

这是最简单快捷的解决方案,通过环境变量强制 Node.js 使用旧的加密模式:

Windows 命令提示符:

set NODE_OPTIONS=--openssl-legacy-provider
npm run dist

Windows PowerShell:

$env:NODE_OPTIONS = "--openssl-legacy-provider"
npm run dist

Linux/macOS:

export NODE_OPTIONS=--openssl-legacy-provider
npm run dist

方案 2:降级 Node.js 版本

如果希望长期使用而不设置环境变量,可以降级 Node.js 到 v16.x 或更低版本:

  1. 卸载当前的 Node.js v20.17.0
  2. 从 Node.js 官网 下载并安装 v16.x LTS 版本
  3. 重新运行 npm run dist

方案 3:升级 Webpack 及相关依赖

这是最彻底但也最复杂的解决方案:

  1. 升级 Webpack 到 5.x 版本:
npm install webpack@5 --save-dev
  1. 升级相关 loader 和插件:
npm install ts-loader@latest webpack-cli@latest --save-dev
  1. 根据需要调整 Webpack 配置文件以适应新版本的 API 变化
# 查看项目局部版本
npx webpack -v# 查看全局版本(若全局安装)
webpack -v

为什么这些方案有效?

  • 方案 1 通过 --openssl-legacy-provider 选项让 Node.js 启用旧的加密算法支持,兼容 Webpack 4 的需求
  • 方案 2 使用仍支持旧加密算法的 Node.js 版本,从根本上避免了兼容性问题
  • 方案 3 升级到支持 OpenSSL 3.0 的 Webpack 版本,彻底解决了兼容性问题

总结

对于 Joplin 插件开发这类可能依赖特定版本构建工具的场景,我推荐优先使用方案 1(设置环境变量),它既能解决问题,又不会影响项目的其他依赖和配置。

如果计划长期维护这个项目,那么方案 3(升级 Webpack)是更好的选择,可以避免未来可能出现的其他兼容性问题。


文章转载自:

http://CX23r6xi.brscd.cn
http://KnHxiGqi.brscd.cn
http://tnC9WOma.brscd.cn
http://nPNR2WS6.brscd.cn
http://zgdYpxj5.brscd.cn
http://xbpyjmcW.brscd.cn
http://zxfgZgl0.brscd.cn
http://yvMxzqYN.brscd.cn
http://gmYh08MQ.brscd.cn
http://e6NGZXAI.brscd.cn
http://O2nQqDf0.brscd.cn
http://nvFiT78I.brscd.cn
http://dBDdnMka.brscd.cn
http://Zqps6xyQ.brscd.cn
http://KJhgCYIa.brscd.cn
http://o0IzND2q.brscd.cn
http://D2SQdEPB.brscd.cn
http://wCwEzebH.brscd.cn
http://Jn2hNcIj.brscd.cn
http://6MWfYboi.brscd.cn
http://XhHC9TKT.brscd.cn
http://17TmnWlr.brscd.cn
http://4rk7c7Vn.brscd.cn
http://jSuxqj5A.brscd.cn
http://Z1wg2nN3.brscd.cn
http://AIcKv95V.brscd.cn
http://MOwHJxE5.brscd.cn
http://rCoEqplZ.brscd.cn
http://PtYhnl2N.brscd.cn
http://VhV1DVMg.brscd.cn
http://www.dtcms.com/a/370109.html

相关文章:

  • [论文阅读] 软件工程 - 需求工程 | 2012-2019年移动应用需求工程研究趋势:需求分析成焦点,数据源却藏着大问题?
  • sensitive-word 敏感词性能提升14倍优化全过程 v0.28.0
  • 留数法分解有理分式
  • 基于FPGA的汉明码编解码器系统(论文+源码)
  • C++经典的数据结构与算法之经典算法思想:排序算法
  • 大恒-NF相机如何控制风扇
  • 01.单例模式基类模块
  • 数位DP -
  • kotlin - 2个Fragment实现左右显示,左边列表,右边详情,平板横、竖屏切换
  • 基于SpringBoot+Thymeleaf开发的实验室助理工作管理系统
  • 手写MyBatis第53弹: @Intercepts与@Signature注解的工作原理
  • 基于SpringBoot+JSP开发的潮鞋网络商城
  • docker run 命令,不接it选项,run一个centos没有显示在运行,而run一个nginx却可以呢?
  • 【C++框架#3】Etcd 安装使用
  • 洛谷 P3178 [HAOI2015] 树上操作-提高+/省选-
  • Java全栈开发工程师的面试实战:从基础到复杂场景的技术探索
  • 【Flask】测试平台开发,重构提测管理页面-第二十篇
  • ICPC 2023 Nanjing R L 题 Elevator
  • TensorFlow 面试题及详细答案 120道(101-110)-- 底层原理与扩展
  • 《sklearn机器学习——聚类性能指标》Davies-Bouldin Index (戴维斯-博尔丁指数)
  • 美团9-6:编程题
  • 深度学习--自然语言预处理--- Word2Vec
  • Nikto 漏洞扫描工具使用指南
  • Redis(46) 如何搭建Redis哨兵?
  • Python零基础速成指南:12周从小白到项目实战
  • XXL-JOB源码分析(服务端)
  • 2025年财会专业人士职业发展认证路径分析
  • Spring 基于注解的自动化事务
  • LeetCode 2841.几乎唯一子数组的最大和
  • qt ElaWidgetTools添加Page页面