百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

重大SBOM风险预警 | 总下载量超百万次开源NPM组件被投毒

ztj100 2025-04-02 00:33 3 浏览 0 评论

SBOM情报概述

近日(2025.03.25),悬镜供应链安全情报中心在NPM官方仓库(http://www.npmjs.com)中捕获1起针对全球知名薪酬数据统计平台 PayScale 旗下开源NPM组件 country-currency-map的供应链投毒事件。country-currency-map 是一款可以帮助前端开发人员快速获取货币和国家/地区关系,便于开发国际化应用的开源组件。截至目前 country-currency-map 组件在NPM官方仓库总下载量已超过百万次。


country-currency-map组件的上个版本(2.1.7)发布时间为 2020年4月7号,时隔5年后(2025.03.25),PayScale 官方账号(npm@payscale.com)在NPM上发布最新版本 2.1.8,而该版本组件代码被投毒者植入混淆的恶意代码, 一旦安装该组件则会静默触发执行恶意代码,其主要功能是启动定时器,每隔5分钟将受害者系统的环境变量数据发送到投毒者服务器,倘若系统环境变量中保存开发者的业务系统私钥、API Token等敏感凭证,将进一步加剧业务系统遭受供应链攻击的风险。

目前country-currency-map组件仍正常托管在NPM官方仓库及国内各大主流镜像源,对于NPM开发者来说存在较大安全隐患。悬镜安全已于第一时间将该组件投毒的详细技术分析向XSBOM供应链安全情报订阅用户进行推送预警。



根据NPM官方接口统计,country-currency-map 组件仅NPM官方仓库总下载量已超过百万次(1175713)。


Bash
https://npm-stat.com/api/download-counts?from=2017-01-01&until=2025-03-26&package=country-currency-map


Github上的country-currency-map项目源码为2.1.7安全版本,未遭受投毒攻击。此外,根据Github项目依赖统计数据,超过170个github开源项目使用country-currency-map组件。考虑到该开源组件的下载量以及使用量,此次投毒攻击是个典型的供应链攻击事件,而攻击根源我们推测是PayScale平台的NPM账号密码或NPM auth token被投毒者盗取导致。



投毒分析

01 代码混淆

country-currency-map组件最新2.1.8版本的package.json文件被投毒者植入postinstall指令实现安装时静默执行"node ./scripts/launch.js"命令。


scripts/launch.js 文件代码被混淆保护,如下所示:


scripts/launch.js 混淆代码还原后,主要代码功能是调用child_process模块进一步执行同目录下的JS文件
scripts/diagnostic-report.js。


diagnostic-report.js文件同样被混淆处理,如下图所示:



2

系统环境变量外传

diagnostic-report.js 混淆代码还原后,其恶意代码主要功能是通过setTimeout()接口启动定时器,每隔5分钟调用collectEnv()函数将系统环境变量数据进行base64编码后再外传到投毒者webhook接口(
https://eoi2ectd5a5tn1h.m.pipedream.net)。


3

IoC 数据

本次捕获的NPM投毒组件包涉及的IoC数据如下表所示:



排查方式

1. 开发者可通过命令 npm list country-currency-map@2.1.8 在项目目录下使用查询是否已安装存在恶意投毒的组件版本,如果已安装请立即使用 npm install country-currency-map@2.1.7 将存在投毒的版本卸载并回退到安全版本。此外还需关闭系统网络并排查系统是否存在异常进程。

2. 此外,也可使用 OpenSCA-cli 工具将受影响的组件包按如下示例保存为db.json文件,直接执行扫描命令(opensca-cli -db db.json -path ${project_path}),即可快速获知您的项目是否受到投毒包影响。

[

{

"product": "country-currency-map",

"version": "[2.1.8]",

"language": "javascript",

"id": "XMIRROR-MAL45-DE0AF19",

"description": "country-currency-map组件2.1.8版本存在代码投毒窃取系统环境敏感信息",

"release_date": "2025-03-25"

}

]

悬镜供应链安全情报中心是国内首个数字供应链安全情报研究中心。依托悬镜安全团队强大的供应链SBOM管理与监测能力和AI安全大数据云端分析能力,悬镜云脉XSBOM数字供应链安全情报预警服务通过对全球数字供应链投毒情报、漏洞情报、停服断供情报等进行实时动态监测与溯源分析,可为用户智能精准预警“与我有关”的数字供应链安全情报,提供情报查询、情报订阅、可视化关联分析等企业级服务。

相关推荐

MySQL的10种常用数据类型(列举mysql中常见的数据类型)

MySQL的数据类型常用的数据类型有:整型(xxxint)位类型(bit)...

大数据量惯用优化方法(大数据 量化)

优化人员工作时免不了要接触到大数据量的问题,下面就将平时收集的一些关于大数据量的优化方法整理记录一下,也是和大家一起共享哦。1.应尽量避免在where子句中对字段进行null值判断,否则将导致...

MYSQL有哪些数据类型(mysql数据类型主要包括)

整理下以便查阅,还想吐槽下:这头条怎么就不能给文章分类呢?整数类型...

MySQL 避坑指南之隐式数据类型转换

...

Qt实现表格树控件-自绘树节点虚线

一、开心一刻...

如何在Qt中实现图形打印?(小学一年级数学图形图片打印)

在Qt中,可以使用QPrinter类和QPainter类来实现图形的打印功能。以下是一个简单的示例,演示了如何在Qt中进行图形的打印:...

Qt组件库之桌面图标系统实现(qt组件库之桌面图标系统实现了)

先来看看实现效果之前效果都放在最后,是不是大家不看到最后就走了, ̄□ ̄||,所以打算以后就先放效果在写实现方法。...

QT实现抖动文字和滚动文字,附源码

前言不知道大家有没有发现今天的文章有什么不一样,哈哈,我自己胡拼乱凑弄了一个logo,好不好看就先不说了,最起码萌萌哒...当然这不是今天的重点,在做logo的时候,我原本想让文字动起来的,奈何技术有...

Qt 图形(QPainterPath)(qt图形界面教程)

简述QPainterPath类提供了一个容器,用于绘图操作,可以创建和重用图形形状。...

Qt在数据可视化项目实战:C++仪表板开发

Qt里面搞数据可视化,咱今儿就聊聊怎么用C++整一个漂亮的仪表盘。...

实战PyQt5: 152-QChart图表之日期时间坐标轴

在统计图表中,使用时间作为某一坐标轴的情况非常常见,比如,常见的一年间月度销售统计,财务统计等等。在QChart中提供了日期时间坐标轴QDateTimeAxis类可以方便地将日期和时间添加到图表的坐标...

我的Qt五子棋AI已连胜238局,不服的来战!

AlphaGo之父DemisHassabis曾指出...

Qt 自适应图片之scaled()函数详解

  如何在改变窗口组件的情况下改变窗口背景图片的大小,我们通常会使用Qt自带的scaled()函数;QImage、QPixmap等绘图设备类都提供scaled()函数。...

PyQt5界面美化(一)(pyqt5酷炫界面)

借助FittenCode插件进行PyQt5界面美化!例如从网上找到一张漂亮的UI示意图:接下来借助FittenCode插件一步一步实现如上图中的界面。首先我们先进行提问,它会给出一个大致框架的代码...

多线程Qt下的八条规则(qt多线程直接处理数据)

相信资深Qter都认识GiuseppeD’Angelo,这位有着二十多年Qt开发经验,Qt源码行数贡献的最多的开发者之一,同时也是Qt项目的审批者,所说话的份量不言而喻。原文作者:...

取消回复欢迎 发表评论: