PHP 5.6.x < 5.6.8 多个漏洞

critical Web App Scanning 插件 ID 98831

简介

PHP 5.6.x < 5.6.8 多个漏洞

描述

根据其标题,远程 Web 服务器上运行的 PHP 5.6.x 版本低于 5.6.8。因此,该服务器受到多个漏洞的影响:

- ext/opcache/zend_shared_alloc.c 文件中的 _zend_shared_memdup() 函数中存在不明释放后使用错误,允许未经身份验证的远程攻击者可借此造成不明影响。(CVE-2015-1351)

- PostgreSQL 扩展中 pgsql.c 文件的 build_tablename() 函数中存在空指针取消引用缺陷,这是由于未验证表名称的标记提取所致。经过身份验证的远程攻击者可利用此问题,通过构建的表名称造成拒绝服务情况。(CVE-2015-1352)

- 在 unserialize() 函数调用期间处理 phar 解析时,Phar 组件中存在缓冲区读取溢出错误,这是由于未正确验证用户提供的输入所致。未经身份验证的远程攻击者可利用此问题,造成拒绝服务情况或泄露内存内容。(CVE-2015-2783)

- 文件 ext/phar/phar.c 中的 phar_parse_metadata() 函数中存在内存损坏问题,这是由于分析特别构建的 TAR 存档时未正确验证用户提供的输入所致。未经身份验证的远程攻击者可利用此问题造成拒绝服务情况或任意代码执行。(CVE-2015-3307)

- 在处理 tar、zip 或 phar 等存档文件时,phar_internal.h 文件的 phar_set_inode() 函数中存在多个基于堆栈的缓冲区溢出情形。未经身份验证的远程攻击者可利用这些问题造成拒绝服务情况或执行任意代码。(CVE-2015-3329)

- 处理管道化 HTTP 请求时,Apache2handler SAPI 组件中存在缺陷,未经身份验证的远程攻击者可利用此缺陷,造成拒绝服务情况或执行任意代码。(CVE-2015-3330)

- 多个函数中都存在一个缺陷,这是由于处理或读取文件时未能检查路径中的空字节 (%00) 序列所致。未经身份验证的远程攻击者可向调用这些函数的应用程序提供特别构建输入,利用此问题绕过预期限制并泄露潜在的敏感信息。(CVE-2015-3411、CVE-2015-3412)

- 文件 ext/soap/soap.c 的多个函数中存在一个类型混淆错误,会在调用 unserialize() 时触发。未经身份验证的远程攻击者可利用此问题泄露内存内容,造成拒绝服务情况或执行任意代码。(CVE-2015-4599、CVE-2015-4600)

- 文件 ext/soap/php_encoding.c、ext/soap/php_http.c 和 ext/soap/soap.c 中存在多个类型混淆错误,未经身份验证的远程攻击者可利用这些错误造成拒绝服务情况,或执行任意代码。(CVE-2015-4601)

- 文件 ext/standard/incomplete_class.c 的 __PHP_Incomplete_Class() 函数中存在类型混淆错误,未经身份验证的远程攻击者可利用此错误,造成拒绝服务情况或执行任意代码。(CVE-2015-4602)

- 异常中存在一个类型混淆错误:: 文件 Zend/zend_exceptions.c 内的 getTraceAsString() 函数允许远程攻击者执行任意代码。(CVE-2015-4603)

- 由于捆绑的 libmagic 库(具体是在文件 softmagic.c 的 mget() 函数中)具有缺陷,因此存在拒绝服务漏洞。该函数未能维护某个指针关系。未经身份验证的远程攻击者可利用此问题,通过构建的字符串造成应用程序崩溃。(CVE-2015-4604)

- 由于捆绑的 libmagic 库(具体是在文件 softmagic.c 的 mcopy() 函数中)具有缺陷,因此存在拒绝服务漏洞。函数未能正确处理超过“bytecnt”的偏移。未经身份验证的远程攻击者可利用此问题,通过构建的字符串造成应用程序崩溃。(CVE-2015-4605)

- 当关闭数据库连接时,/ext/sqlite3/sqlite3.c 文件中的 sqlite3_close() 函数存在一个释放后使用错误。未经身份验证的远程攻击者可利用此问题执行任意代码。

- 在处理 __get() 函数调用时,文件 /Zend/zend_vm_def.h 的 ZEND_VM_HELPER_EX() 函数中存在缺陷。未经身份验证的远程攻击者可利用此问题造成拒绝服务。

- ext/standard/http_fopen_wrapper.c 文件中的 php_stream_url_wrap_http_ex() 函数存在类型混淆错误,未经身份验证的远程攻击者可利用此错误执行任意代码。

- ext/curl/interface.c 文件的 php_curl() 函数中存在释放后使用错误,未经身份验证的远程攻击者可利用此错误执行任意代码。

- SPL 组件中存在释放后使用错误,尤其是 ext/spl/spl_observer.c 文件内的 spl_object_storage_get_gc() 函数中。未经身份验证的远程攻击者可利用此问题执行任意代码。

- /ext/ereg/regex/regcomp.c 文件中存在空指针取消引用缺陷,未经身份验证的远程攻击者可利用此错误造成拒绝服务情况。

请注意,扫描程序并未试图利用这些问题,而只依赖于应用程序自我报告的版本号。

解决方案

升级至 PHP 5.6.8 或更高版本。

另见

http://php.net/ChangeLog-5.php#5.6.8

插件详情

严重性: Critical

ID: 98831

类型: remote

发布时间: 2019/1/9

最近更新时间: 2023/10/30

扫描模板: 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-2015-4599

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-1351

漏洞信息

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

可利用: true

易利用性: Exploits are available

补丁发布日期: 2015/3/30

漏洞发布日期: 2015/3/30

参考资料信息

CVE: CVE-2015-1351, CVE-2015-1352, CVE-2015-2783, CVE-2015-3307, CVE-2015-3329, CVE-2015-3330, CVE-2015-3411, CVE-2015-3412, CVE-2015-4599, CVE-2015-4600, CVE-2015-4601, CVE-2015-4602, CVE-2015-4603, CVE-2015-4604, CVE-2015-4605

BID: 71929, 71932, 74204, 74239, 74240, 74413, 74703, 75233, 75241, 75246, 75249, 75250, 75251, 75252, 75255

CWE: 119, 121, 125, 20, 200, 254, 416, 476, 626, 665, 843

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

WASC: Buffer Overflow, Improper Input Handling, Information Leakage

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, 540, 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

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.1.1, 27001-A.14.2.5, 27001-A.14.2.7, 27001-A.14.2.9, 27001-A.15.1.2

NIST: sp800_53-CM-6b, sp800_53-SA-4(3), sp800_53-SI-10, sp800_53-SI-15, sp800_53-SI-16

OWASP API: 2019-API7, 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.1, 3.2-6.5.2, 3.2-6.5.8, 3.2-8.1, 3.2-8.4.3