Nginx 解析漏洞分析

Nginx 解析漏洞

漏洞原因:该漏洞与Nginx、php版本无关,属于用户配置不当造成的解析漏洞。
如果我们上传了一个1.jpg文件,但是访问的是/1.jpg/.php那么fastcgi在处理".php"文件时发现文件并不存在,这时php.ini配置文件中cgi.fix_pathinfo=1 发挥作用,采用上层路径。为此这里交由fastcgi处理的文件就变为了test.png。
漏洞形成要求:
1.php.ini配置文件中cgi.fix_pathinfo=1
2.
在这里插入图片描述

3.php-fpm.conf中的security.limit_extensions配置项没有进行限制fastcgi解析文件的类型。
在这里插入图片描述
此项选项为空代表fastcgi将可以将.jpg等文件当做代码解析。
如果设置为如下:

security.limit_extensions = .php

那么此漏洞将无法造成。此设置的意思为只可以将以php结尾的文件当作php文件解析执行。
漏洞演示:
漏洞环境:vulhub docker
启动环境是一个上传页面:
在这里插入图片描述
进入docker查看index.php文件内容,定义了一个白名单只可以上传jpg文件,并对文件名进行了md5重明白(代表了CVE-2013-4547漏洞失效):
在这里插入图片描述

在这里插入图片描述
因为经过了getimagesize()函数验证所以我们上传一个以内容GIF89A开头的写了phpinfo的jpg文件:
在这里插入图片描述

上传成功后进行恶意访问/uploadfiles/f3ccdd27d2000e3f9255a7e3e2c48800.jpg/wa1ki0g.php:
在这里插入图片描述
成功执行phpinfo

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值