聚焦源代码安全,网罗国内外最新资讯!

编译:代码卫士团队

专栏·供应链安全

数字化时代,软件无处不在。软件如同社会中的“虚拟人”,已经成为支撑社会正常运转的最基本元素之一,软件的安全性问题也正在成为当今社会的根本性、基础性问题。

随着软件产业的快速发展,软件供应链也越发复杂多元,复杂的软件供应链会引入一系列的安全问题,导致信息系统的整体安全防护难度越来越大。近年来,针对软件供应链的安全攻击事件一直呈快速增长态势,造成的危害也越来越严重。

为此,我们推出“供应链安全”栏目。本栏目汇聚供应链安全资讯,分析供应链安全风险,提供缓解建议,为供应链安全保驾护航。

注:以往发布的部分供应链安全相关内容,请见文末“推荐阅读”部分。

安全研究员表示,攻击者本可利用已在包管理器PEAR中存在15年之久的多个漏洞破坏PHP生态系统。目前漏洞已修复。

瑞士安全公司 SonarSource 的漏洞研究员 Thomas Chauchefoin 指出,密码重置函数的弱熵中存在一个漏洞,可导致PEAR开发人员账户遭恶意接管。之后,攻击人员可通过滥用过时捆绑依赖版本中的另外一个漏洞,获得对PEAR中心服务器的永久访问权限。

这些缺陷已存在超过15年的时间。Chauchefoin 指出,这些缺陷由安全研究员而非攻击者发现是“幸运逃脱”,因为“PEAR仓库遭攻陷,可导致攻击者劫持托管在平台上的任意包”并公开恶意发布。

需最少的技术专业知识

自PHP包管理器 Composer 占据主导地位后,PEAR 已失宠。不过SonarSource 公司的研究员去年同样在Composer 主仓库中发现了一个类似的严重漏洞。

然而,PEAR 仍使用广泛,单是每个月通过 PHP 安装器下载的 Net_SMTP 和 Mail 包就高达10万次。

Chauchefoin 指出, “威胁行动者仅需最少的技术专业知识就能轻松找到并利用” 这些供应链漏洞,“在全球引发重大破坏和安全泄露事件”。

尝试50次即可获得有效的密码重置令牌

PEAR 的密码重置函数使用 mt_rand () 生成随机值,即使该技术已过时并不适合生成加密安全值。一旦通过 md5() 拼接并对这些值进行哈希,“最终的值仅基于两个未知值,即mt_rand() 和 time() 的输出。第一个函数无法生成很多值(10),第二个函数可轻松遭攻击者预测。另外,pear.php.net 的HTTP 服务器在响应中增加了Data 标头,将其仅缩小到某些数量的值(<5)。”

研究人员总结称,攻击者尝试50次以内就能够确保一个合法的密码重置令牌。

Chauchefoin 指出,即使第一个漏洞已被修复,但第二个漏洞提供的后门可被继续用于发动攻击,“它还可通过修改访问日志来隐藏踪迹”。这个漏洞产生的原因在于 pearweb 拉取Archive_Tar 的版本14.7易受 CVE-2020-36193 影响,该漏洞是一个目录遍历漏洞,可导致在PEAR上执行远程代码。

研究人员在2021年7月30日将这些漏洞告知 PEAR 维护人员。这两个漏洞已在3月13日发布的pearweb 版本1.32中修复了这些漏洞,所有之前的版本均受影响。

然而,Chauchefoin 建议PEAR用户“迁移至 Composer,因为Composer 的贡献者社区更加活跃,并且也存在同样的程序包”。

太多信任

针对PEAR和类似开发者工具的软件供应链攻击具有重大影响,因为开发人员经常会在部署到生产服务器之前在计算机上运行这些工具,“从而使攻击者能够跳转到企业的内部网络中”。

这些PEAR 缺陷已存在如此长的时间,说明依赖于包管理器的资源丰富的企业保护措施还不够。研究人员解释称,“包管理器的后端服务仅获得安全贡献人员的少量关注,然而,这些后端服务是每种语言生态的中心组件。”

Chauchefoin 援引 Composer、CocoaPods 和 RubyGems中的缺陷时指出,“以后还会出现类似漏洞,因此清除我们给予后端服务的信任将减少这些漏洞的影响;sigstore 是一个不错的解决方案,我们应当推动它的采用。”


代码卫士试用地址:https://codesafe.qianxin.com/

开源卫士试用地址:https://oss.qianxin.com


推荐阅读

在线阅读版:《2021中国软件供应链安全分析报告》全文

从主流安全开发框架看软件供应链安全保障的落地

速修复!这个严重的Zlib内存损坏漏洞已存在17年!

攻击者“完全自动化”发动NPM供应链攻击

Pwn2Own大赛回顾:利用开源服务中的严重漏洞,攻陷西部数据My Cloud PR4100

Node-ipc 热门包作者投毒“社死‘’,谁来保护开源软件供应链安全?

因供应商遭不明网络攻击,丰田汽车宣布停产

Linux Netfilter 防火墙模块爆新漏洞,攻击者可获取root权限

丰田汽车顶级供应商 Denso 疑遭勒索攻击,被威胁泄露商业机密

漏洞Dirty COW:影响Linux系统以及安卓设备

第三方支付处理厂商软件有漏洞,日本美容零售商Acro 10万支付卡信息遭攻击

Linux 内核 cgroups 新漏洞可导致攻击者逃逸容器

谷歌宣布 Linux Kernel、Kubernetes 0day 漏洞奖励加倍

Apache Cassandra 开源数据库软件修复高危RCE漏洞

2021年软件供应链攻击数量激增300%+

热门开源CMS平台 Umbraco 中存在多个安全漏洞,可使账户遭接管

详细分析开源软件项目 Ajax.NET Professional 中的RCE 漏洞(CVE-2021-23758)

SAP 严重漏洞可导致供应链攻击

Apache PLC4X开发者向企业下最后通牒:如不提供资助将停止支持

Apache 软件基金会:顶级项目仍使用老旧软件,补丁作用被削弱

美国商务部发布软件物料清单 (SBOM) 的最小元素(上)

美国商务部发布软件物料清单 (SBOM) 的最小元素(中)

美国商务部发布软件物料清单 (SBOM) 的最小元素(下)

NIST 发布关于使用“行政令-关键软件”的安全措施指南

NIST 按行政令关于加强软件供应链安全的要求,给出“关键软件”的定义及所含11类软件

SolarWinds 攻击者再次发动供应链攻击

美国“加强软件供应链安全实践的指南” (SSDF V1.1草案) 解读来了

软件供应链安全现状分析与对策建议

“木马源”攻击影响多数编程语言的编译器,将在软件供应链攻击中发挥巨大作用

GitHub 在 “tar” 和 npm CLI 中发现7个高危的代码执行漏洞

流行的 NPM 包依赖关系中存在远程代码执行缺陷

速修复!热门npm 库 netmask 被曝严重的软件供应链漏洞,已存在9年

Npm 恶意包试图窃取 Discord 敏感信息和浏览器文件

微软“照片”应用Raw 格式图像编码器漏洞 (CVE-2021-24091)的技术分析

SolarWinds 供应链事件后,美国考虑实施软件安全评级和标准机制

找到软件供应链的薄弱链条

GitHub谈软件供应链安全及其重要性

揭秘新的供应链攻击:一研究员靠它成功入侵微软、苹果等 35 家科技公司

开源软件漏洞安全风险分析

开源OS FreeBSD 中 ftpd chroot 本地提权漏洞 (CVE-2020-7468) 的技术分析

集结30+漏洞 exploit,Gitpaste-12 蠕虫影响 Linux 和开源组件等

限时赠书|《软件供应链安全—源代码缺陷实例剖析》新书上市

热门开源CI/CD解决方案 GoCD 中曝极严重漏洞,可被用于接管服务器并执行任意代码

GitKraken漏洞可用于盗取源代码,四大代码托管平台撤销SSH密钥

因服务器配置不当,热门直播平台 Twitch 的125GB 数据和源代码被泄露

彪马PUMA源代码被盗,称客户数据不受影响

原文链接

https://portswigger.net/daily-swig/supply-chain-flaws-in-php-package-manager-pear-lay-undiscovered-for-15-years

题图:Pixabay License

本文由奇安信编译,不代表奇安信观点。转载请注明“转自奇安信代码卫士 https://codesafe.qianxin.com”。

奇安信代码卫士 (codesafe)

国内首个专注于软件开发安全的产品线。

 觉得不错,就点个 “在看” 或 "赞” 吧~

PHP包管理器PEAR 中爆多个缺陷可发动供应链攻击,已潜伏15年相关推荐

  1. 黑客在数十个 WordPress 插件和主题中插入秘密后门,可发动供应链攻击

     聚焦源代码安全,网罗国内外最新资讯! 编译:代码卫士 专栏·供应链安全 数字化时代,软件无处不在.软件如同社会中的"虚拟人",已经成为支撑社会正常运转的最基本元素之一,软件的安全 ...

  2. javascript原理_JavaScript程序包管理器工作原理简介

    javascript原理 by Shubheksha 通过Shubheksha JavaScript程序包管理器工作原理简介 (An introduction to how JavaScript pa ...

  3. Windows 程序包管理器 1.0 正式发布

    在 Microsoft Build 2021 开发者大会上,微软正式发布 Windows Package Manager(程序包管理器)1.0 正式版,目前在 GitHub 上已有超过 1600 个程 ...

  4. 从 vue3 和 vite 源码中,我学到了一行代码统一规范团队包管理器的神器

    1. 前言 大家好,我是若川.最近组织了源码共读活动,感兴趣的可以加我微信 ruochuan12 参与,每周大家一起学习200行左右的源码,共同进步.已进行四个月了,很多小伙伴表示收获颇丰. 想学源码 ...

  5. Windows中使用包管理器(类似于apt/yum的) - Chocolatey

    Windows中使用包管理器 - Chocolatey简介 李俊才 的 CSDN 博客 邮箱 :291148484@163.com CSDN 主页:https://blog.csdn.net/qq_2 ...

  6. Linux 中的包管理器是什么?它是如何工作的?

    文章目录 1.Linux 中的包管理器是什么? 2.什么是包? 3.包管理器如何工作? 4.不同类型的包管理器 1.Linux 中的包管理器是什么? Linux 发行版之间的主要区别之一是包管理系统( ...

  7. 以rpm为后端及以yum为前端工具的程序包管理器在Linux发行版系统centos中的使用...

    程序包管理: 应用程序的安装,实际上是解压缩并复制程序包中的文件到指定目录的过程: 程序包管理器: 方便终端用户进行程序的安装.卸载.升级.安装信息查询及校验等工作: 不同的Linux的发行版本中,有 ...

  8. opm openresty的包管理器-中文文档

    2022年1月11日13:57:45 官方:https://opm.openresty.org/ 官方文档:https://opm.openresty.org/docs#table-of-conten ...

  9. VSCode中npm包管理器安装到卸载

    学习视频: https://www.bilibili.com/video/BV1BU4y147pS?p=21&spm_id_from=pageDriver npm包管理器安装到卸载 npm包管 ...

最新文章

  1. 查拉斯图拉的“没落”
  2. c:forEach循环的List为String时的写法
  3. 力扣——整数反转(Java)
  4. IM设计思考:XMPP多用户文本聊天协议(MUC:Multi User Chat)
  5. IHS Infonetics:网络运营商进军SDN
  6. 前端学习(2344):打包和部署
  7. MVC常见的控制器,接口,数据层之间的操作
  8. Symbian手记【三】 —— Symbian的描述符
  9. [vscode] 推荐插件及配置
  10. autosar架构详细介绍_干货|非常详细的 Ceph 介绍、原理、架构
  11. eclipse的控制台显示有问题,关闭Limit console output
  12. java上传图片裁剪_浅谈java图片上传之剪切
  13. KaTeX|LaTeX数学公式编辑手册
  14. 第二十五章 合作博弈论【相关策略与相关均衡】
  15. 【PR 2021】Adobe Premiere 2021 软件下载及安装教程
  16. Qt5+STM32F407+步进电机 | 通过电脑控制步进电机实现:6+2通道、速度可变、运动精确步数的教程——基础知识(2/4)
  17. shader篇-透明效果
  18. Vulkan_Ray Tracing 09_反射
  19. prefetch()
  20. python折叠次数计算、一张纸5毫米_关于一张纸的对折次数 五

热门文章

  1. centos7下cups + samba共打印服务
  2. [LINUX] 误删了/lib 怎么办?
  3. 生成32位字母数字的随机数
  4. SCCM 2007系列教程之四在工作组环境内实现SCCM客户端
  5. 走近Flex组件系列(四):分组组件(Box)、分割组件(DividedBox)和容器组件(Panel)
  6. 10 款最新的 jQuery 内容滑块插件
  7. 易观的大数据革命 分析师与机器人协同办公
  8. C# 本质论 第二章 数据类型
  9. Android CircleImageView圆形ImageView
  10. Linux内核第二节