[漏洞复现]——nginx目录穿越漏洞

前言

曾记得面试时被问到这个漏洞,当时没答上来,所以好好学习一下

原理

Nginx (engine x) 是一个高性能的HTTP和反向代理服务器,Nginx经常被做为反向代理,动态的部分被proxy_pass传递给后端端口,而静态文件需要Nginx来处理。

漏洞出现在服务器的静态文件中。

如果静态文件存储在/home/目录下,而该目录在url中名字为files,那么就需要用alias设置目录的别名:

 

url上/files没有加后缀/,而alias设置的/home/是有后缀/的,这个/就导致我们可以从/home/目录穿越到他的上层目录(具体也不太理解,后续补上)

漏洞验证 

复现漏洞

环境搭建

Ubuntu 16.04 + Nginx 1.11.3

获得root权限
sudo -i

安装nginx依赖库和gcc g++的依赖库
apt-get install build-essential
apt-get install libtool

安装pcre依赖库
apt-get install libpcre3 libpcre3-dev

安装zlib依赖库
apt-get install zlib1g-dev

安装ssl依赖库
apt-get install openssl

安装nginx
wget http://nginx.org/download/nginx-1.11.3.tar.gz

解压
tar -zxvf nginx-1.11.3.tar.gz

进入解压目录:
cd nginx-1.11.3

配置:
./configure --prefix=/usr/local/nginx

安装nginx:
make

启动nginx:
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

访问是否搭建成功

 修改Nginx配置文件

apt-get install vim
vim /usr/local/nginx/conf/nginx.conf

效果如图

重启Nginx

cd /usr/local/nginx
./sbin/nginx -s reload

验证漏洞

正常访问

目录穿越

 

漏洞修复

重启Nginx

 

cd /usr/local/nginx
./sbin/nginx -s reload

 

参考:

nginx目录穿越漏洞复现 - 雨中落叶 - 博客园 

Nginx目录穿越漏洞 - Eleven_Liu - 博客园

<think>好的,用户想查找关于PHP反序列化漏洞phpshexxe的复现方法或案例。首先,我需要确认phpshexxe是否是一个已知的漏洞名称,或者是否有拼写错误。可能用户指的是某个特定CMS或框架的反序列化漏洞,比如phpshe、PHPCMS或其他类似名称的项目。 根据提供的引用,用户提到了PHP反序列化漏洞,相关引用[1]、[2]、[3]都涉及PHP反序列化,尤其是引用[1]详细解释了漏洞触发的原因。引用[2]提到了一个具体的URL和复现步骤,可能是一个实际案例。引用[3]提到了CTF中的PHP反序列化考点,可能涉及利用方法。虽然引用[4]和[5]是关于Fastjson的Java漏洞,但用户的问题集中在PHP上,所以可能需要忽略这些。 接下来,我需要检查是否存在名为phpshexxe的漏洞。可能用户将phpshe和XXE(XML外部实体注入)混淆,或者是指某个特定应用。假设phpshexxe是phpshe的某个反序列化漏洞,需要查找是否有相关案例。 根据现有引用,引用[2]提到一个具体的PHPMyAdmin setup.php反序列化漏洞复现步骤,这可能是一个类似的案例。此外,引用[3]中的CTF题目可能涉及PHP反序列化的利用,可能提供思路。 用户可能需要具体的复现步骤,包括环境搭建、漏洞触发点、利用链构造和Payload生成。需要结合PHP反序列化的基本原理,如魔术方法(__wakeup, __destruct等)的利用,以及如何构造恶意序列化数据。 需要确保回答符合系统级指令:使用正确的中文,行内公式用$...$,独立公式用$$...$$,但当前问题可能不需要数学公式。生成相关问题,并正确引用提供的参考。 可能存在的信息缺口是具体的phpshexxe漏洞细节,如果该漏洞不存在或名称有误,需要指出可能的拼写错误,并提供通用复现方法。同时,需要引用提供的参考资料,尤其是引用[1]、[2]、[3]中的内容。 最后,生成相关问题,确保问题与PHP反序列化漏洞相关,帮助用户深入理解。</think>### PHP反序列化漏洞(phpshexxe)复现方法与案例分析 PHP反序列化漏洞通常因未对用户输入的序列化数据严格过滤,导致恶意代码执行或敏感数据泄露。根据引用[^1],漏洞触发核心在于反序列化时自动调用魔术方法(如`__destruct`、`__wakeup`),攻击者可构造恶意对象实现注入。 --- #### **复现步骤示例(以PHPMyAdmin setup.php漏洞为例)[^2]** 1. **环境搭建** - 部署存在漏洞的PHP版本(如PHP 5.x)及目标应用(如旧版phpMyAdmin)。 - 启动Web服务(Apache/Nginx)并配置数据库。 2. **漏洞触发点定位** - 目标文件:`scripts/setup.php`,通过参数传递未过滤的序列化数据。 - 构造Payload:序列化包含恶意代码的类实例。 ```php class Exploit { public $payload = "system('id');"; public function __destruct() { eval($this->payload); } } $exploit = serialize(new Exploit()); echo $exploit; // 生成恶意序列化字符串 ``` 3. **漏洞利用** - 发送构造的Payload至目标接口: ```http GET /phpmyadmin/scripts/setup.php?data=O:7:"Exploit":1:{s:7:"payload";s:10:"system('id');";} ``` - 若成功,服务器会执行`id`命令并返回结果。 --- #### **关键利用条件** 1. 存在可被反序列化的类且其魔术方法包含危险操作。 2. 反序列化入口未对输入数据进行验证或过滤。 --- #### **防御建议** 1. 禁用`unserialize()`函数或严格校验输入数据。 2. 使用`json_decode()`替代序列化操作。 3. 限制敏感魔术方法的执行权限。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值