返回首页

Trivy安全扫描器沦为蠕虫载体:CanisterWorm供应链攻击复盘与防御指南

Trivy安全扫描器沦为蠕虫载体:CanisterWorm供应链攻击复盘与防御指南

Trivy供应链攻击CanisterWorm

Aqua 旗下Trivy漏洞扫描器遭黑客组织TeamPCP入侵,被武器化为自我传播的蠕虫"CanisterWorm",在24小时内感染超过60个npm包。安全工具本身成为最大安全风险。

事件概述:当安全工具变成攻击武器

2026年3月中旬,安全行业经历了一次前所未有的供应链攻击事件。Aqua Security旗下的Trivy——全球最广泛使用的开源漏洞扫描工具之一——被黑客组织TeamPCP入侵并武器化。攻击者不仅污染了Trivy本身,还利用窃取的凭据启动了一个名为"CanisterWorm"的自我传播蠕虫,在npm生态系统中造成了连锁感染。

这次攻击的讽刺之处在于,Trivy正是用来检测供应链攻击的安全工具。当安全工具本身成为攻击向量时,整个软件供应链的信任基础被动摇。Palo Alto Networks在其分析报告中指出:"Trivy供应链攻击展示了安全工具如何被武器化——你用来保护代码的扫描器,可能正在向你的代码中注入恶意软件。"

事件的时间线清晰地展示了攻击者的精密策划:3月中旬,TeamPCP通过 Actions的漏洞入侵了Trivy的构建流程;随后,恶意代码被注入到Trivy的npm发布包(v0.69.4版本)中;攻击者窃取了大量npm发布凭据;最终利用这些凭据启动了CanisterWorm蠕虫,在24小时内自动感染了超过47个npm包,并在后续几天扩展到75个GitHub Action标签。

攻击链分析:五阶段精密打击

根据Picus Security、Palo Alto Networks和The Stack的多份分析报告,整个攻击链可以分为五个阶段:

阶段一:初始入侵。TeamPCP通过Trivy的GitHub Actions工作流中的漏洞获得了初始访问权限。具体方式可能涉及供应链依赖的劫持或GitHub Actions的权限配置缺陷。攻击者获得了对Trivy代码仓库的写入权限。

阶段二:恶意代码注入。攻击者在Trivy的构建流程中注入了恶意代码,发布了被污染的v0.69.4版本。该版本在表面上功能正常,但包含了一个隐蔽的后门,会在执行扫描时窃取本地凭据。

阶段三:凭据收割。被污染的Trivy版本在用户环境中运行时,会自动收集npm令牌(npm )、GitHub Personal Access Tokens和其他凭据。这些凭据被发送到攻击者控制的C2服务器。

阶段四:CanisterWorm启动。利用收割到的npm凭据,TeamPCP部署了CanisterWorm——一个自我传播的npm蠕虫。该蠕虫的特殊之处在于它使用区块链智能合约作为不可追踪的命令控制(C2)基础设施。

阶段五:生态扩散。CanisterWorm通过被窃取的凭据自动向受害者的npm包中注入恶意代码,每个被感染的包又会进一步感染其依赖者的环境。这种自我传播机制在24小时内感染了超过60个npm包。

攻击阶段 时间窗口 影响范围 攻击手法
初始入侵 3月初 Trivy仓库 GitHub Actions漏洞利用
恶意注入 3月中旬 Trivy v0.69.4 构建流程劫持
凭据收割 3月中下旬 全球Trivy用户 恶意扫描器窃取npm/GitHub令牌
蠕虫启动 3月下旬 npm生态系统 自我传播+区块链C2
生态扩散 持续中 47+ npm包, 75+ GitHub标签 凭据驱动的自动感染

CanisterWorm技术特征:区块链驱动的不可追踪蠕虫

CanisterWorm在技术上具有几个显著的创新特征,使其区别于传统的供应链恶意软件:

自我传播机制:CanisterWorm不需要攻击者手动操作每个感染环节。一旦获得有效的npm发布令牌,蠕虫会自动修改受害者维护的npm包代码,在其中注入自身的副本。当其他开发者安装被感染的包时,蠕虫会检查本地是否存在可用的npm令牌,如果存在则继续传播。

区块链C2基础设施:这是CanisterWorm最令人不安的特征。传统的C2服务器可以通过域名封禁、IP封锁等方式切断。但CanisterWorm使用以太坊智能合约存储命令和配置数据,使得C2通信完全分散化且不可审查。安全研究人员无法简单地"关停"区块链上的智能合约。

隐蔽性设计:蠕虫的恶意载荷被精心混淆,使用动态加载和代码分割技术逃避静态分析。被感染的npm包在功能上保持正常,仅在安装后的postinstall脚本中执行恶意逻辑。The Hacker 的报道指出,该蠕虫还使用了"延迟执行"策略,在安装后数小时甚至数天才激活恶意功能。

# 检查本地npm环境是否受到CanisterWorm影响
# 1. 检查npm令牌是否可能已泄露
npm config list | grep "//registry.npmjs.org"

# 2. 检查最近安装的包是否有异常postinstall脚本
find node_modules -name "package.json" -exec \
  grep -l "postinstall" {} \; 2>/dev/null | head -20

# 3. 检查是否存在已知被感染的包版本
# 参考Aqua Security和Palo Alto Networks发布的IoC列表
npm ls | grep -i "trivy\|aquasecurity"

# 4. 审计GitHub Actions工作流
cat .github/workflows/*.yml | grep -i "trivy\|setup-trivy"

# 5. 撤销并轮换所有npm和GitHub令牌
npm token revoke <token_id>
# 在GitHub Settings → Developer settings → Personal access tokens中删除旧token

受影响组件:Trivy生态全面沦陷

此次攻击不仅影响了Trivy的npm包,还波及了整个Trivy生态系统:

Trivy npm包:v0.69.4版本被确认为恶意版本。任何在此版本发布后通过npm安装或更新Trivy的用户都可能受到影响。

GitHub Actionsaquasecurity/setup-trivyaquasecurity/trivy-action这两个广泛使用的GitHub Action也被入侵。据Palo Alto Networks统计,共75个GitHub Action标签被篡改。

下游npm包:CanisterWorm通过窃取的凭据感染了至少47个独立的npm包。这些包分布在多个npm scope下,总下载量可能达到数百万次。

CI/CD流水线:任何在CI/CD流程中使用被污染版本Trivy的项目,其构建环境中的npm和GitHub凭据都可能已被窃取。这意味着即使项目代码本身没有被修改,其发布凭据可能已经被用于感染其他项目。

防御措施:供应链安全的系统性加固

针对此次事件及类似供应链攻击,企业和开发者应采取以下防御措施:

# 1. 立即检查并更新Trivy到安全版本
npm list -g | grep trivy
npm  -g trivy  # 确保更新到安全版本

# 2. 审计GitHub Actions中的Trivy引用
# 检查所有仓库的.github/workflows目录
find . -path "*/.github/workflows/*.yml" -exec \
  grep -l "aquasecurity/trivy" {} \;

# 3. 锁定依赖版本,避免自动拉取最新版
# package.json中使用精确版本号
# "trivy": "0.69.5"  而非 "^0.69.0"

# 4. 启用npm包完整性验证
npm config set package-lock true
npm ci  # 使用lockfile安装,而非npm install

# 5. 使用Sigstore/cosign验证npm包签名
npx sigstore verify npm <package-name>

# 6. 检查npm包的异常网络连接
# 使用strace监控安装过程
strace -f -e trace=network npm install 2>&1 | grep -i "connect"

# 7. 使用Socket.dev等工具检测供应链风险
npx socket npm ls
防御层 措施 工具/方法 优先级
版本锁定 使用lockfile和精确版本号 npm ci, pnpm install --frozen-lockfile P0
签名验证 验证包的数字签名 Sigstore, cosign P1
行为监控 监控安装时的网络和文件操作 Socket.dev, Snyk P1
凭据隔离 CI/CD中使用短期令牌和最小权限 GitHub OIDC, npm granular tokens P1
依赖审计 定期审查依赖树和变更 npm audit, Dependabot P2

行业反思:安全工具的信任悖论

CanisterWorm事件暴露了安全行业的一个深层矛盾:我们用来保护软件供应链的工具,本身就是供应链的一部分,因此也可以成为攻击目标。当Trivy这样的安全扫描器被武器化时,开发者面临一个两难困境——不使用安全工具会被已知漏洞攻击,使用安全工具可能被供应链攻击。

Palo Alto Networks的建议是采用"多层防御"策略:不要依赖单一的安全工具,而是组合使用多个不同供应商的工具进行交叉验证。例如,同时使用Trivy、Snyk和Grype进行漏洞扫描,如果其中一个被入侵,异常结果可以通过其他工具发现。

此外,此次事件也凸显了CI/CD安全的重要性。GitHub Actions的权限模型需要更加精细化——发布令牌应使用短期有效的OIDC令牌而非长期静态令牌,工作流的每一步都应该有明确的权限边界和审计日志。

数据来源

评论