PHP 7.0.x < 7.0.3 多个漏洞

critical Web App Scanning 插件 ID 98848

简介

PHP 7.0.x < 7.0.3 多个漏洞

描述

据横幅广告可知,远程 Web 服务器上运行的 PHP 版本为低于 7.0.3 的 7.0.x。因此,该服务器受到多个漏洞的影响:

- Perl-Compatible Regular Expressions (PCRE) 库受到多个漏洞影响,这些漏洞与正则表达式、子例程调用和二进制文件有关。远程攻击者可利用这些漏洞导致拒绝服务、获取敏感信息或造成其他不明影响。(CVE-2015-8383、CVE-2015-8386、CVE-2015-8387、CVE-2015-8389、CVE-2015-8390、CVE-2015-8391、CVE-2015-8393、CVE-2015-8394)

- escapeshellcmd() 和 escapeshellarg() 函数的 ext/standard/exec.c 文件中存在一个缺陷,造成此缺陷的原因是字符串中的空字节被程序截断。远程攻击者可利用此漏洞绕过限制。

- stream_get_meta_data() 函数的 ext/standard/streamsfuncs.c 文件中存在一个缺陷,造成此缺陷的原因是无法限制将用户提供的数据写入尚未设置的字段。远程攻击者可借此伪造函数的输出,进而导致插入恶意的元数据。

- 反序列化 WDDX 数据包时,php_wddx_pop_element() 函数的 ext/wddx/wddx.c 文件中存在一个类型混淆错误。远程攻击者可以利用此错误造成不明影响。

- PharFileInfo: getContent() 方法的 ext/phar/phar_object.c 文件中存在一个缺陷,: 造成此缺陷的原因是由于使用未初始化内存导致不当验证用户提供的输入。远程攻击者可利用此缺陷造成内存损坏,从而导致拒绝服务或执行任意代码。

- 解析特别构建的 TAR 文件的元数据时,phar_tar_setupmetadata() 函数的 ext/phar/tar.c 文件中存在一个空指针取消引用缺陷。远程攻击者可利用此缺陷造成拒绝服务。

- iptcembed() 函数的 ext/standard/iptc.c 文件中存在整数溢出,造成此漏洞的原因是不当验证用户提供的输入。远程攻击者可借此造成基于堆的缓冲区溢出,进而导致拒绝服务或执行任意代码。

- phar_parse_tarfile() 函数的 ext/phar/tar.c 文件中存在溢出,造成此漏洞的原因是解压缩 TAR 文件时不当验证用户提供的输入。远程攻击者可借此造成基于堆栈的缓冲区溢出,进而导致拒绝服务或执行任意代码。(CVE-2016-2554)

请注意,扫描程序并未测试这些问题,而是仅依据应用程序自我报告的版本号进行判断。

解决方案

升级至 PHP 7.0.3 或更高版本。

另见

http://php.net/ChangeLog-7.php#7.0.3

插件详情

严重性: Critical

ID: 98848

类型: remote

发布时间: 2019/1/9

最近更新时间: 2023/3/14

扫描模板: api, basic, full, pci, scan

风险信息

VPR

风险因素: Medium

分数: 6.7

CVSS v2

风险因素: Critical

基本分数: 10

矢量: CVSS2#AV:N/AC:L/Au:N/C:C/I:C/A:C

CVSS 分数来源: CVE-2016-2554

CVSS v3

风险因素: Critical

基本分数: 9.8

矢量: CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H

CVSS 分数来源: CVE-2015-8383

漏洞信息

CPE: cpe:2.3:a:php:php:*:*:*:*:*:*:*:*

可利用: true

易利用性: Exploits are available

补丁发布日期: 2015/12/2

漏洞发布日期: 2015/12/2

参考资料信息

CVE: CVE-2015-8383, CVE-2015-8386, CVE-2015-8387, CVE-2015-8389, CVE-2015-8390, CVE-2015-8391, CVE-2015-8393, CVE-2015-8394, CVE-2016-2554, CVE-2016-4342

BID: 79810, 82990, 83353, 89154

CWE: 119, 120, 121, 185, 189, 190, 200, 407, 665, 908

OWASP: 2010-A1, 2010-A6, 2013-A1, 2013-A5, 2013-A9, 2017-A1, 2017-A6, 2017-A9, 2021-A1, 2021-A3, 2021-A6

WASC: Buffer Overflow, Improper Input Handling, Information Leakage, Integer Overflows

CAPEC: 10, 100, 101, 104, 108, 109, 110, 116, 120, 123, 13, 135, 136, 14, 153, 169, 182, 209, 22, 224, 23, 230, 231, 24, 250, 261, 267, 28, 285, 287, 290, 291, 292, 293, 294, 295, 296, 297, 298, 299, 3, 300, 301, 302, 303, 304, 305, 306, 307, 308, 309, 31, 310, 312, 313, 317, 318, 319, 320, 321, 322, 323, 324, 325, 326, 327, 328, 329, 330, 42, 43, 44, 45, 46, 47, 472, 473, 497, 508, 52, 53, 573, 574, 575, 576, 577, 588, 59, 60, 616, 63, 64, 643, 646, 651, 67, 7, 71, 72, 73, 78, 79, 8, 80, 81, 83, 85, 88, 9, 92

DISA STIG: APSC-DV-000460, APSC-DV-002560, APSC-DV-002590, APSC-DV-002630

HIPAA: 164.306(a)(1), 164.306(a)(2)

ISO: 27001-A.12.6.1, 27001-A.14.2.5

NIST: sp800_53-CM-6b, sp800_53-SI-10, sp800_53-SI-15, sp800_53-SI-16

OWASP API: 2019-API7, 2019-API8, 2023-API8

OWASP ASVS: 4.0.2-14.2.1, 4.0.2-5.1.3, 4.0.2-8.3.4

PCI-DSS: 3.2-6.2, 3.2-6.5, 3.2-6.5.2, 3.2-6.5.8