metinfo 5.0.4 文件包含 漏洞复现 / 源码分析

metinfo 5.0.4 文件包含

源码分析

/metinfo_5.0.4/about/index.php

包含了 /metinfo_5.0.4/include/module.php 文件

并且动态包含了 $module,而 $module 未在此页面定义,猜测其在包含的 module.php 文件中有相关定义

image-20231115104601313

/metinfo_5.0.4/include/module.php

$module 在 module 中首次出现在判断执行的语句中,当变量 $fondule不等于 7 时,对 $module 进行初始化操作。

image-20231115105421167

在 index.php 中,$fmodule 的值被赋为 1,所以在包含调用 module.php 文件时,$fmodule 不等于 7 则会对 $module 进行初始化。

在这里插入图片描述

文件包含语句 require_once $module; 会调用默认代码直接显示页面内容

image-20231115110457155

/metinfo_5.0.4/include/common.inc.php

查找改变 $fmodule$module 的值,即如何对 $fmodule$module 传参

发现 module.php 文件还包含了 common.inc.php 文件

image-20231115105902053

接收传参代码位置

image-20231115111947842

添加输出语句验证传参

echo $_key."=>".$_value."<br />";

image-20231115113502209

在这里插入图片描述

漏洞复现

由源码分析可知,当传入参数 $fmodule 等于 7 时,不会对 $module 进行初始化,此时传入参数为变量 $module 进行赋值即可实现文件包含

POC:

/metinfo_5.0.4/about/index.php?fmodule=7&module=

执行 phpinfo 文件

image-20231115114032228

读取 hosts 文件

image-20231115114153242

  • 10
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

gjl_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值