要想开启PUT,需要修改PHPstudy的配置文件。
data:image/s3,"s3://crabby-images/d9971/d99717e51d25143bbf5f7b45768e3cac94e1283a" alt=""
?根据路径打开配置文件,启用模块,记得对修改的模块备份
启用模块
data:image/s3,"s3://crabby-images/11ed2/11ed233b665c282c5aca20fc5bdaaf663dfa8ac6" alt=""
?添加目录
data:image/s3,"s3://crabby-images/827d8/827d8964372da387b7a2e66375350e1a44295a4d" alt=""
根据自己的路径修改,记得保存,重启服务 ,
可以通过BP抓取上传文件的包,对上传类型进行修改,也可通过kali自带的cadaver来实现
data:image/s3,"s3://crabby-images/8af43/8af436fff6f18b5ba2b5544cea883ba98bc59d76" alt=""
?通过help可以指定支持哪些命令使用?
data:image/s3,"s3://crabby-images/b0b41/b0b416842c19e913c5f7931d1e8e38024a29ee4b" alt=""
lls是查看本机的文件,ls是查看服务器的文件,通过put上传一句话木马,使用蚁剑链接。
data:image/s3,"s3://crabby-images/627d6/627d67de113a279d2f8b611ec096ee686e4126b8" alt=""
?蚁剑成功连接,
data:image/s3,"s3://crabby-images/c8844/c8844935397fc5397fc2482de086b993501eb321" alt=""
而目录下也有1.php?
metinfov5.0.4
data:image/s3,"s3://crabby-images/6d074/6d074d36adf4dea906ac2e8bdf992fa348068d6c" alt=""
?漏洞位置
http://192.168.40.137/MetInfo5.0.4/admin/include/uploadify.php
uploadify.php
data:image/s3,"s3://crabby-images/a62cb/a62cb402de5a82d6f452e601bdebcc2e7adf66f0" alt=""
看到包含"common.inc.php"? 查看
?看到在管理员权限一栏有SQL认证,但并未添加过滤,存在绕过。
data:image/s3,"s3://crabby-images/a5d2e/a5d2ee352944cb8af1a1c2f1d3994fe9d653bcd5" alt=""
文件上传类型也有限制?
data:image/s3,"s3://crabby-images/7fab8/7fab8b95665c5b80f6cd7b58dec71716939099c7" alt=""
可以采用双写绕过(pphphp)?
编写表单
<html>
<form enctype="multipart-data" method="post"
name="myForm"
action="http://192.168.40.137/MetInfo5.0.4/admin/include/uploadify.php?
、、metinfo_admin_id=root&metinfo_admin_pass=root&met_admin_table=met_admin_table#&type=upfile&met_file_format=jpg|pphphp
">
<input name="Filedata" type="file" size=20>
<input type="submit" name="Submit" value="0.0">
</html>
data:image/s3,"s3://crabby-images/0259f/0259fff4558d2b21dc5bdd12c6608731ae87ad3c" alt=""
metinfov5.0.4的10.21更新
基于面对代码,进行代码审计,利用工具对整个网站的代码进行一个扫描审计
data:image/s3,"s3://crabby-images/294da/294daa23ce516699ac096b5e05d23caf8314f18e" alt=""
看到可能存有文件包含漏洞,对源码进行一个访问。
data:image/s3,"s3://crabby-images/c0619/c0619d90996a5540f3a06be84827fa964ceeb2b6" alt=""
可以看到 require_once $module,还有require_once '../include/module.php',对module.php进行查看。
data:image/s3,"s3://crabby-images/7e891/7e891d2e33bfab3b395fb46fa906061797570173" alt=""
找到$module,?在没有对$module传参的时候,直接返回一个404.html,最下面对$module给予了一个值,且文件开头又包含了另一个文件
data:image/s3,"s3://crabby-images/642d1/642d16b23da53405286032f2ba6fb49328efbcb6" alt=""
进行访问
data:image/s3,"s3://crabby-images/2d9d2/2d9d213095f37a9e267c09f7fa422a774c84213a" alt=""
?看到cookei、post、get、三个传参方法,中间还有$$_request,? $_key是键,$value是值,
对该串代码进行测试
data:image/s3,"s3://crabby-images/61bf0/61bf0c62f9d488743a75cce050f550ea11453cce" alt=""
?访问:
data:image/s3,"s3://crabby-images/c065d/c065dc422e9782c5463ccf4dd5f7bfe940ca1cd4" alt=""
看到输出了Feng_Blue
对$name进行修改
data:image/s3,"s3://crabby-images/03c86/03c868360461f9e3db094ecc2d650106d0c6ac8f" alt=""
?在url中对name进行赋值,但源文件中并没有修改,发现在url传递的参数直接覆盖了源文件中的内容。
name=Feng_Blue
name被当成变量名,Feng_Blue为参数值,不传参就输出定义过的name,传参则就覆盖原文件内的name的值,是一个变量覆盖漏洞。
此时我们回到../adout/index/php
data:image/s3,"s3://crabby-images/c0619/c0619d90996a5540f3a06be84827fa964ceeb2b6" alt=""
尝试替换带$module
data:image/s3,"s3://crabby-images/8ae5d/8ae5d130e2576c9702a92e11f0537c7186163207" alt=""
?而此时发现,并没有覆盖掉$module,对源代码进行修改,尝试print一下这个$module,记得备份。
data:image/s3,"s3://crabby-images/6cfff/6cfffbea0a0abf15341301cf49c6d0ba3d644f91" alt=""
?保存源码后刷新data:image/s3,"s3://crabby-images/72441/7244188d809f66a1883a06f686828c495d388640" alt=""
?弹出show.php,再进行赋值:data:image/s3,"s3://crabby-images/3744f/3744f4bdf70fc55c82a9f9bbe58dae580e26e5da" alt=""
依旧回显show.php,说明对这个?$module初始化了。
data:image/s3,"s3://crabby-images/c0619/c0619d90996a5540f3a06be84827fa964ceeb2b6" alt=""
?我们回头查看module.php
data:image/s3,"s3://crabby-images/88d2e/88d2e84451ff1729b6dcc0d4aef2b8a8cc5bce6e" alt=""
?当$fmodule不等于7的时候进行初始化,而我们需要让它等于7。因为$module再if分支。
尝试:
data:image/s3,"s3://crabby-images/07e2b/07e2bd77c3680ea55732b5af8418e405e92f3288" alt=""
?成功
data:image/s3,"s3://crabby-images/70ae5/70ae5508ccc1537983eb9887059d5e8bc4393fbd" alt=""
?查看:\windows\system32\drivers\etc\hosts
文件包含漏洞复现