Node.js版本与项目的兼容性问题解决方案
创作时间:
作者:
@小白创作中心
Node.js版本与项目的兼容性问题解决方案
引用
CSDN
1.
https://blog.csdn.net/TullyL/article/details/144299826
本文将介绍一个常见的Node.js版本与项目兼容性问题,特别是与OpenSSL相关的问题。文章详细描述了一个具体的错误场景,并提供了多个解决方案,包括设置环境变量、降级Node.js版本和修改package.json等。
报错原因
这个错误是由于Node.js版本与项目的兼容性问题导致的。你遇到的是OpenSSL相关的错误,这在较新版本的Node.js中比较常见。
解决方案
方案1 - 设置环境变量(推荐):
在Windows命令行中运行以下命令:
set SET NODE_OPTIONS=--openssl-legacy-provider
然后重新运行:
npm start
方案2 - 降级Node.js:
1. 卸载当前的Node.js v22.11.0
2. 安装Node.js v16.x LTS版本
3. 重新运行 npm install && npm start
方案3 - 修改package.json:
将scripts部分的start命令修改为:
{
"scripts": {
"start": "set SET NODE_OPTIONS=--openssl-legacy-provider && react-scripts start"
}
}
建议使用方案1,因为这是最简单且不需要修改项目文件的方法。如果还是不行,可以尝试:
- 清除node_modules:
rm -rf node_modules - 清除package-lock.json:
rm package-lock.json - 重新安装:
npm install - 设置环境变量:
set SET NODE_OPTIONS=--openssl-legacy-provider - 启动项目:
npm start
这个问题主要是因为你使用的Node.js v22.11.0版本太新,而项目可能使用了一些较旧的依赖包。
Successful operation
详细报错
Microsoft Windows [版本 10.0.22000.2538]
(c) Microsoft Corporation。保留所有权利。
E:\React\react-bilibli-ToDoList>cd..
E:\React>cd weatherApp-Reactjs-master
E:\React\weatherApp-Reactjs-master>npm i && npm start
npm warn cleanup Failed to remove some directories [
npm warn cleanup [
npm warn cleanup 'E:\\React\\weatherApp-Reactjs-master\\node_modules\\watchpack-chokidar2',
npm warn cleanup [Error: EPERM: operation not permitted, rmdir 'E:\React\weatherApp-Reactjs-master\node_modules\watchpack-chokidar2\node_modules\string_decoder'] {
npm warn cleanup errno: -4048,
npm warn cleanup code: 'EPERM',
npm warn cleanup syscall: 'rmdir',
npm warn cleanup path: 'E:\\React\\weatherApp-Reactjs-master\\node_modules\\watchpack-chokidar2\\node_modules\\string_decoder'
npm warn cleanup }
npm warn cleanup ]
npm warn cleanup ]
Starting the development server...
Error: error:0308010C:digital envelope routines::unsupported
at new Hash (node:internal/crypto/hash:79:19)
at Object.createHash (node:crypto:139:10)
at module.exports (E:\React\weatherApp-Reactjs-master\node_modules\webpack\lib\util\createHash.js:135:53)
at NormalModule._initBuildHash (E:\React\weatherApp-Reactjs-master\node_modules\webpack\lib\NormalModule.js:417:16)
at handleParseError (E:\React\weatherApp-Reactjs-master\node_modules\webpack\lib\NormalModule.js:471:10)
at E:\React\weatherApp-Reactjs-master\node_modules\webpack\lib\NormalModule.js:503:5
at E:\React\weatherApp-Reactjs-master\node_modules\webpack\lib\NormalModule.js:358:12
at E:\React\weatherApp-Reactjs-master\node_modules\loader-runner\lib\LoaderRunner.js:373:3
at iterateNormalLoaders (E:\React\weatherApp-Reactjs-master\node_modules\loader-runner\lib\LoaderRunner.js:214:10)
at iterateNormalLoaders (E:\React\weatherApp-Reactjs-master\node_modules\loader-runner\lib\LoaderRunner.js:221:10)
E:\React\weatherApp-Reactjs-master\node_modules\react-scripts\scripts\start.js:19
throw err;
^
Error: error:0308010C:digital envelope routines::unsupported
at new Hash (node:internal/crypto/hash:79:19)
at Object.createHash (node:crypto:139:10)
at module.exports (E:\React\weatherApp-Reactjs-master\node_modules\webpack\lib\util\createHash.js:135:53)
at NormalModule._initBuildHash (E:\React\weatherApp-Reactjs-master\node_modules\webpack\lib\NormalModule.js:417:16)
at E:\React\weatherApp-Reactjs-master\node_modules\webpack\lib\NormalModule.js:452:10
at E:\React\weatherApp-Reactjs-master\node_modules\webpack\lib\NormalModule.js:323:13
at E:\React\weatherApp-Reactjs-master\node_modules\loader-runner\lib\LoaderRunner.js:367:11
at E:\React\weatherApp-Reactjs-master\node_modules\loader-runner\lib\LoaderRunner.js:233:18
at context.callback (E:\React\weatherApp-Reactjs-master\node_modules\loader-runner\lib\LoaderRunner.js:111:13)
at E:\React\weatherApp-Reactjs-master\node_modules\babel-loader\lib\index.js:59:103 {
opensslErrorStack: [
'error:03000086:digital envelope routines::initialization error',
'error:0308010C:digital envelope routines::unsupported'
],
library: 'digital envelope routines',
reason: 'unsupported',
code: 'ERR_OSSL_EVP_UNSUPPORTED'
}
Node.js v22.11.0
E:\React\weatherApp-Reactjs-master>
热门推荐
这几种安全避孕方式,你选对了吗?
吃苦菊对身体的好处
解锁 AI “因果密码” !YOCSEF 广州大模型技术思辨风暴来袭
小白也能打造高性能电脑!从CPU到机箱的全面配置指南
免费开放!儒学典籍《儒藏》将上线数字化智能平台
活血化瘀的药酒有哪些
紫泥和紫砂的区别
紫泥与紫砂,揭秘两者的区别与联系
住房维修基金可以要回来吗?
电力工程优化设计与节能技术研究
2024海外品牌国产新车质量:排名迎大调整,特斯拉夺得冠军
A股市场蓝筹股投资指南:价值分析与风险评估
肩关节不稳术后康复完全指南:从伤口护理到力量训练
历史视角下的黄巢:英雄还是反贼?
白萝卜亩产量多少斤?——提高产量的技巧
認識英國短毛貓
袜子泡多久洗最好?专家教你正确护理袜子的方法
罗马蘋丘:最浪漫的日落观赏地
揭秘科幻大片背后的科学事实
雨燕自动变速箱的换挡平顺性如何?该变速箱的维护成本高吗?
反复出现同一梦境,代表什么?如何解析这种梦?
灰指甲的四大成因及科学应对方法
HR如何引导员工融入企业文化?从问题到解决方案的深度解析
第二届中国行业媒体融合发展创新案例:内容作品类案例解析
如何预防儿童口腔溃疡的发生及治疗方法详解
口腔内有一个水泡有时候消了
如何胜任数据库工程师
办公家具能否通过创新设计提升企业空间利用效率?
运用认知行为疗法改善老年人抑郁症状的实践研究
观影设备大比拼!激光电视与传统液晶电视,谁才是家庭影院的首选?全面解析