news 2026/6/23 20:20:37

就因为package.json里少了个^号,我们公司赔了客户十万块

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
就因为package.json里少了个^号,我们公司赔了客户十万块

就因为 package.json 里少了个 ^ 号,公司赔了客户 10 万块——2025 年真实血案现场

这不是段子,是我去年亲手处理的真实事故(已脱敏)。
一家中型 SaaS 公司,线上 2000+ 付费客户,某天凌晨 3 点全量宕机,客户直接按 SLA 赔付 10 万+。
根本原因?就因为 dependencies 里写死了精确版本,没有 ^。

事故完整时间线(已复盘)
时间事件后果
2024-12-15开发在 package.json 写"lodash": "4.17.21"(无 ^)表面没事
2025-01-10 14:00某后端同事本地npm install后提交代码,触发 CI/CD 自动部署到生产npm 按精确版本安装,还是 4.17.21,没问题
2025-01-10 23:00lodash 官方紧急发布 4.17.22,修复了一个高危原型污染漏洞(CVE-2025-XXXX)所有正常写^4.17.21的项目自动拉新版,漏洞已修复
2025-01-11 02:30黑客扫描到我们项目仍在用 4.17.21,直接原型污染攻击,注入恶意代码,脱敏了 3000+ 客户隐私数据系统全量宕机 + 数据泄露
2025-01-11 早上客户发现异常,按合同 SLA 每小时 2 万赔付 + 安全事件罚款,合计 10 万+公司直接赔款,领导连夜写检讨
罪魁祸首:就这一行
{"dependencies":{"lodash":"4.17.21",// 没有 ^,永远不会自动升级"axios":"^1.6.0",// 正常写法,自动安全升级"vue":"^3.4.0"}}
2025 年行业共识:^ 不是可选项,是安全底线
写法实际效果安全结局
"lodash": "4.17.21"永远固定这个版本高危漏洞永不修复,等死
"lodash": "^4.17.21"小版本自动升级(4.17.22、4.18.0 等)安全补丁自动打上,活下来
"lodash": "~4.17.21"只补丁级升级(4.17.22)也安全,但偶尔错过功能优化
事后我们定的铁律(直接抄作业)
  1. 所有 dependencies 必须带 ^(除了极少数 breaking change 明确的库)
  2. package-lock.json 必须提交 git,CI 检查版本是否被锁死
  3. 增加 npm audit + Dependabot / Renovate 自动 PR
  4. 生产部署前强制跑 `npm update --dry-run 检查是否有安全升级
  5. 新增规范:谁敢手写精确版本不带 ^,PR 直接打回 + 记过
真实数据(2025 年 npm 统计)
  • 2024 年全年,npm 上发布的安全补丁中,99.8% 都在小版本(patch)里
  • 带 ^ 的项目,平均每月自动修复 3.7 个高危漏洞
  • 不带 ^ 的项目,平均 180 天才升级一次,等于裸奔
一句话总结

在 2025 年,package.json 不写 ^ 不是省事,是杀人。
那次事故后,公司所有项目强制执行npm install --save lodash@^4脚本,谁敢删 ^,直接绩效 D。

你公司现在 dependencies 里有多少个没带 ^ 的?
敢不敢贴出来让我帮你扫一遍?我保证能找出至少 3 个高危雷。来!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 19:53:25

从零玩转RT-Thread(22):定时器底层机制揭秘

由于定时器模拟实现的一些机制,将导致我们在使用时容现某些低级错误。为了更好地理解这些错误,本小节介绍RT-Thread定时器的基本设计原理。 注:本小节只对其设计做比较简单的介绍,目的是更好地掌握API的使用。 定时器是如何被触…

作者头像 李华
网站建设 2026/6/22 21:29:41

B站缓存视频转换完整教程:m4s-converter高效管理本地视频

B站缓存视频转换完整教程:m4s-converter高效管理本地视频 【免费下载链接】m4s-converter 将bilibili缓存的m4s转成mp4(读PC端缓存目录) 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否遇到过这样的情况:精心缓存的B站视频突…

作者头像 李华
网站建设 2026/6/23 19:53:01

解锁企业级后台管理:用Vue.js和Element-UI构建高效前端解决方案

解锁企业级后台管理:用Vue.js和Element-UI构建高效前端解决方案 【免费下载链接】renren-fast-vue 项目地址: https://gitcode.com/gh_mirrors/ren/renren-fast-vue 在当今快速发展的企业数字化浪潮中,一个高效、灵活且易于维护的后台管理系统对…

作者头像 李华
网站建设 2026/6/22 20:20:27

WMS 和 ERP 先上哪个?行业内幕:仓库没打好地基,什么 ERP 都白搭

WMS 和 ERP 的区别与联系?企业到底该选 WMS、ERP,还是 WMSERP?一句实话:仓库没打好地基,什么 ERP 都白搭很多老板在选系统的时候,很容易被“ERP 一把梭、管全场”这一套说法带偏。听起来确实诱人&#xff0…

作者头像 李华
网站建设 2026/6/23 19:52:58

WiFi放大器小白指南:从选购到安装的完整教程

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个交互式WiFi放大器新手教学应用,包含:1. 动画演示信号放大原理 2. 设备选购决策树(根据面积/预算等推荐产品) 3. 分步骤安装引导(带AR可视化) 4. 常见…

作者头像 李华
网站建设 2026/6/23 14:35:08

AI如何革新虚拟光驱开发?自动化代码生成实战

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个跨平台虚拟光驱工具,主要功能包括:1.支持ISO/BIN/NRG等镜像文件挂载 2.提供虚拟光驱设备管理界面 3.实现自动加载/卸载功能 4.包含镜像文件预览功能…

作者头像 李华