关于npm install时sha512- ... but got sha512-... 问题记录
创始人
2025-05-29 16:19:13
0

问题描述

在接手一个项目npm install 时遇到了如下问题
在这里插入图片描述
导致npm 包不能正常安装

问题分析

在进行问题分析前,先说一点基础知识,在npm资源管理网站,当作者每一次发布npm包或者更新版本时,npm资源管理网站都会为这个包或者新版本自动生成一个hash值,用于确保这个包的完整性,正常来说npm资源管理是不允许删除和更改npm包的,用户只能追加版本,但是npm并没有限制死,即一个包在发布24小时内作者是可以删除重新发布的,一旦作者进行了这样的操作,即便这两次包的版本号一样,但是这两次的hash值是不一样的。
另外,在我们为项目npm install 安装项目包时,我们会发现在项目的根目录还会自动生成一个package-lock.json的文件,这个文件就是用来锁定项目的依赖包版本。即我们在自己的package.json中可以定义我们要安装的包比如vue但是vue里又依赖了哪些包,他们的版本号是多少我们是无法确定的,因此对于一个项目开发来说,为了避免一个团队不同人之间开发依赖包不一致造成的开发问题,通常都需要对项目的依赖包版本锁死,这样不同人在npm install的时候不仅本项目的npm包一致,同样项目包所涉及的依赖包也是一致的。这就是package-lock.json的作用(温馨提示:千万不要在gitignore中把package-lock.json屏蔽喔,想必你已经知道为啥了😊)
通过上述了解,在根据具体情况分析发现是我这个包的npm源遭到更改或破坏了,导致前后两次的这个包的integrity(完整性约束)的hash值不一样。从而导致无法正常安装。
通俗的将就是一个npm包比如lodash v4.17.21这个版本刚发布不久,就被一个开发者把这个包安装到自己的项目中并push到远程仓库,但是lodash的作者可能觉得这个包有缺陷,然后就把这个版本删除了又重新发了一个 v4.17.21版本,尽管这两版本一样,但是他们的integrityhash值已经发生改变了。所以当后来人在重新进行npm install进行安装时,由于package-lock.json记录了lodash v4.17.21旧的integrity,这就造成从npm资源库找到的这个lodash v4.17.21版本的integrity值和package-lock.json里记录的不一致,因此就无法正常安装。

解决方案

一、删除package-lock.json这个文件夹,重新安装
但是这种方法不推荐,如果是一个刚搭架没多久的项目可能没什么关系,但是一旦这个项目是一个已经好几年的老项目,你在删除package-lock.json后,重新安装时,就会造成一些包的依赖项和原来不一致,此时你很难保证这些依赖项有没有进行过重大更新,一旦出现和以前版本不兼容的情况,就会导致整个项目无法正常启动。
二、根据npm报错的sha…值到package-lock.jsonctrl + f 找到是哪个具体包的integrity,然后把这个包的整体信息删除。重新npm install 这样整个安装过程就只会更改有问题的这个包,并且package-lock.json会重新生成这个包的依赖项。
三、和二类似,就是如果能从报错信息中明确看到是哪个具体的包,可以直接先执行 npm uninstall '包名' 把这个包卸载了,然后在执行npm install 最后不要忘记把这个已经卸载的包也重新安装回来,此时package-lock.json也会自动更新这个包的信息生产新的integrity值

相关内容

热门资讯

商业航天概念股密集“降温”:有... 1月12日,A股成交额达3.64万亿元,创历史新高;全天逾4100只个股上涨,逾200只个股涨停;板...
“套壳”谷歌Gemini ,但... 苹果“低头”了。当地时间1月12日,苹果和谷歌发布联合声明:“经过仔细评估,苹果公司认为谷歌的人工智...
上纬新材:若股价进一步上涨,将... 新京报贝壳财经讯 1月12日,上纬新材发布股票交易风险提示公告,公司股票价格自2025年7月以来累计...
蓝箭电子:拟现金收购成都芯翼科... 新京报贝壳财经讯 1月12日,蓝箭电子发布公告称,公司拟筹划以现金方式收购成都芯翼科技有限公司不低于...
急着去海底挖?日企说:没中国稀... 稀土管制精准 “锁喉”,日本工业扛得住吗?中国对日本收紧稀土出口管制,日本果然急了。1月12日外交部...
石头科技港股 IPO 遇三重劫... 文|恒心来源|博望财经石头科技港股上市之路再迎新动作。据《第一财经》等多家媒体报道,2026年1月5...
伊朗外长:大量证据显示美以参与... 当地时间12日,伊朗外长阿拉格齐就近期伊朗局势举行新闻发布会。 阿拉格齐表示,自2025年12月28...
“与美国为敌或许危险,做美国盟... 文/卜森“如果阮文绍的下场和吴廷琰一样,那么世界各国就会明白,与美国为敌或许危险,做美国盟友将会致命...
梁文锋署名,DeepSeek论... 2026.01.13本文字数:1017,阅读时长大约2分钟作者 |第一财经 刘晓洁继去年底发布一篇新...
上市以来首现巨亏,疫苗龙头爆雷... 疫苗龙头,经历了上市以来最艰难的一年。昨日夜间,重庆智飞生物制品股份有限公司(简称智飞生物,3001...