【AICon】探索八个行业创新案例,教你在教育、金融、医疗、法律等领域实践大模型技术! >>> 了解详情
写点什么

最近 Npm 的意外事件暴露了安全漏洞

  • 2018-01-23
  • 本文字数:803 字

    阅读完需:约 3 分钟

看新闻很累?看技术新闻更累?试试下载 InfoQ 手机客户端,每天上下班路上听新闻,有趣还有料!

最近,npm 注册库经历了一次运维的意外事件,导致一些被高度依赖的包变得不可用,比如 require-from-string。尽管这个意外事件非常易于修复,但是它暴露了一个较为严重的安全漏洞,借助该漏洞能够尝试将恶意代码注入到使用npm 的项目中。

按照官方报告的说法,这次意外事件的根本原因在于错误地将名为“floatdrop”的用户移除,并使他们的包无法查找和下载。之所以做出这样的决策是因为发布了一个包含垃圾软件的包,该包中还包含了floatdrop 的合法包 timed-out的 README。因为匹配了 README,所以 npm 的反垃圾系统将 floatdrop 标记为垃圾包,随后导致了移除用户及其所有的包的操作。

npm 快速发现 floatdrop 确实是一个合法的用户,并且他们的有些包被高度使用,所以他们立即采取行动恢复所有的包。但就在这个过程所需的短短时间内,有一些与删除包名称相同的新包发布了,并且安装数目不详。

尽管 npm 的员工确认所有这些上传的替代包并非恶意的,但是这种事件有可能会给 npm 用户的项目注入恶意代码。需要注意的是,npm 确实有一个策略,用来防止发布时间超过24 小时的包被删除掉,其目的在于让其他人无法重用这些包的名字,但是这项策略之前并没有应用到垃圾软件包的删除上。这样做的理由是不想让垃圾软件妨碍合法名称的使用。

作为对这起事件的回应,npm 的员工采取了几项措施,其中最重要的就是对所有删除的包名有一个24 小时的冷却(cooldown)时间,这项策略也包括含有垃圾内容的包。这样的话,通过替换已删除的包来注入恶意代码会变得更困难,但是如果有人试图重用合法的包名的话,这需要npm 的员工在24 小时的时间窗口内恢复该包名。

另外,npm 的员工将会建立一系列的指导文档,让合法包名的误删更加难以出现。读者可以在原始博客文章中了解更多信息。

查看英文原文 Last Npm Incident Uncovers Security Vulnerability

2018-01-23 18:002185

评论

发布
暂无评论
发现更多内容

【Flutter 专题】73 图解自定义 ACECheckBox 复选框

阿策小和尚

Flutter 小菜 0 基础学习 Flutter Android 小菜鸟 8月日更

从0开始的TypeScriptの二:类型系统

空城机

JavaScript typescript 8月日更

毕业设计

CR

【架构实战营】模块四作业

Abner S.

架构实战营 #架构实战营

最后的作业-秒杀设计

大肚皮狒狒

[架构实战营]模块四作业

xyu

#架构实战营

大数据训练营一期 0801 作业

朱磊

架构实战营模块4作业

喻高咏        

架构训练营

Docker新手FAQ系列 1

混沌畅想

模块四作业

VE

架构实战营

考试试卷存储方案

伏波

架构

[架构实战营][模块四作业]

KK_TTN

架构实战营

iOS开发:上架遇到NSBluetoothAlwaysUsageDescription被拒问题(已解决)

三掌柜

8月日更 8月

毕业设计-电商秒杀系统

chenmin

架构实战营-毕业总结

阿体

架构实战营 模块四作业

三叔叔_拖延症晚期

架构实战营第一期--模块四作业

clay

架构实战营

《Financial Management 101》读书笔记

箭上有毒

8月日更

架构训练营毕业设计

Geek_e0c25c

架构实战营

架构实战营 毕业设计

iProcess

架构实战营

架构实战营1期第四模块作业——高性能高可用存储

tt

架构实战营

设计千万级学生管理系统的考试试卷存储方案

木云先森

架构训练营

架构实战营总结

chenmin

架构实战营 毕业设计

Dylan

架构实战营

netty系列之:中国加油

程序那些事

Java Netty nio 程序那些事

大数据训练营 -0801 课后作业

cc

合适即是王道

林建

设计电商秒杀系统

thewangzl

字节跳动《实时音视频通讯技术》学习笔记之RTC概述及技术简介

Regan Yue

音视频 RTC 8月日更

模块4作业

柱林

kubernetes入门:dashboard可视化界面部署springboot项目

小鲍侃java

8月日更

最近Npm的意外事件暴露了安全漏洞_JavaScript_Sergio De Simone_InfoQ精选文章