摘要:本文将详细介绍如何解决在 Node.js 环境中遇到的 error:0308010C:digital envelope routines::unsupported
错误。我们将探讨这个错误的原因,并提供多种解决方案,帮助您顺利地继续开发和部署工作。
1. 错误背景
error:0308010C:digital envelope routines::unsupported
错误通常出现在使用 Node.js 17 或更高版本时。这是由于 Node.js 17 默认启用了 OpenSSL 3.0,而 OpenSSL 3.0 对于某些加密算法的支持有所改变,导致在构建或运行某些应用程序时出现问题。
2. 理解错误原因
此错误通常与 Node.js 应用程序中的加密操作有关,特别是在使用 Webpack 或其他构建工具时。错误提示表明 Node.js 无法正确处理数字信封(digital envelope)的加密操作。
3. 解决方案
3.1 临时解决方案:设置环境变量
最简单的临时解决方案是设置 NODE_OPTIONS
环境变量,以禁用 OpenSSL 3.0 中的某些特性。
- 在 Unix/Linux 系统中,可以在命令行中设置:
export NODE_OPTIONS=--openssl-legacy-provider
- 在 Windows 系统中,可以在命令行中设置: