CVE-2019-11043: PHP-FPM在Nginx特定配置下任意代码执行漏洞预警
2019-10-25 11:53:32 Author: mp.weixin.qq.com(查看原文) 阅读量:89 收藏

本文转自安全客 

https://www.anquanke.com/post/id/189415

0x00 漏洞背景

2019年10月23日, 360CERT监测到 PHP 官方发布了在 nginx 配置不当的情况下 php-fpm 可导致远程代码执行的漏洞更新。

判断漏洞等级为中危,影响面有限。

但由于是配置文件的开放性。还请使用 nginx+php-fpm 的服务管理员/运维人员及时做好自查自检工作。

0x01 漏洞详情

在 https://github.com/php/php-src/blob/master/sapi/fpm/fpm/fpm_main.c#L1150 中由于\n(%0a)的传入导致nginx传递给php-fpm的PATH_INFO为空。

进而导致可以通过FCGI_PUTENV与PHP_VALUE相结合,修改当前的php-fpm进程中的php配置。在特殊构造的配置生效的情况下可以触发任意代码执行。

注:完全复制Nginx官方给出的php-fpm示例配置的用户受到此漏洞影响

示例配置如下:

PHP FastCGI Example | NGINX

漏洞证明:

使用配置文件

0x02 修复建议

  1. 修改 nginx 配配置文件中fastcgi_split_path_info的正则表达式,不允许.php之后传入不可显字符

  2. 暂停使用 nginx+php-fpm 服务

  3. 删除如下配置

     fastcgi_split_path_info ^(.+?\.php)(/.*)$;
    fastcgi_param PATH_INFO       $fastcgi_path_info;

0x03 时间线

2019-10-21 PHP 官方发布漏洞更新

2019-10-23 360CERT发布预警

0x04 参考链接

  1. PHP :: Sec Bug #78599 :: env_path_info underflow in fpm_main.c can lead to RCE

本文由安全客原创发布 
链接
: https://www.anquanke.com/post/id/189415 


文章来源: http://mp.weixin.qq.com/s?__biz=MjM5MTYxNjQxOA==&mid=2652852470&idx=2&sn=2d0d7f070a44da069f54fd50347af857&chksm=bd592c3b8a2ea52dde09081bc1ec731e592779a2e4ed9fe3b44647f30ad08f5c4eacb0c9254b#rd
如有侵权请联系:admin#unsafe.sh