android 删除文件 代码_代码审计之某系统后台存在任意删除文件

dee74ae00e0e7bc5dc215775fdf19a83.png

本文作者:霾

团队交流群:673441920

-----------------------------------------------------------

前言

POC镇楼!!!

POST 

漏洞演示过程:

首先我们利用D盾监听下我们的项目以外的目录。

1358eda9ade7801b853d11fea6a68dab.png

这里刚刚我们创建了这个文件现在我们要从CMS去删除他。

acfe67a480b8231d485777ed6db58d5b.png

随便找了一个目录去点击,然后我们用burp去抓包。

e0488945dd0316af4000f70fd5759ec3.png

我们去修改下fname这个参数再去删除

297bbacb67c95114e3ebc846cf5cada5.png

这里可以看到我们的文件和文件夹都给删除了。

漏洞审计:

路径:controladmin_filemanager.php

0b99ea123e44c3380fbc889678b90ea1.png

第158行,if(isset($this->post['currentdir']) && isset($this->post['fname'])),判断post中的currentdir是否有设置并且判断fname是否有设置。

第161行,if(!file_exists($fname)),判断文件或者目录是否存在。

第164行,if($this->post['isdir']== '0'),判断isdir的值是否等于0。

第165行,@unlink($fname);,删除文件。

第167行,else if($this->post['isdir'] == '1'),或者判断isdir的值是否等于1。

第168行,$str=$_ENV['dir']->dir_delete($fname);,进入自定义方法。

路径:modeldir.class.php

463c2390909e0e1f05402c654e22acb1.png

第46行,if(!is_dir($dir)) return FALSE;,判断是否是目录。

第47行,$systemdirs = array('', HDWIKI_ROOT.'control', HDWIKI_ROOT.'langzh', HDWIKI_ROOT.'data', HDWIKI_ROOT.'model', HDWIKI_ROOT.'view', HDWIKI_ROOT.'install', HDWIKI_ROOT.'js', HDWIKI_ROOT.'lib', HDWIKI_ROOT.'plugins', HDWIKI_ROOT.'block', HDWIKI_ROOT.'api', HDWIKI_ROOT.'lang', HDWIKI_ROOT.'ss');,声明自定义的路口

第48行,if(substr($dir, 0, 1) == '.' || in_array($dir, $systemdirs)) exit("Cannot remove system dir $dir !");,substr代表字符串切割并且等于.,或者判断数组是否存在值。

第49行,$dir=$dir."";,声明一个变量。

第50行,$list = glob($dir.'*'),glob代表返回匹配指定模式的文件名或目录。

第51行,foreach($list as $v),foreach循环。

第52行,is_dir($v) ? $this->dir_delete($v) : @unlink($v);,3元运算符,is_dir判断是否是目录,如果是目录那么就递归,如果不是目录那么就删除文件。

第54行,@rmdir($dir);,删除文件夹。

漏洞修复:

利用str_replace去吧字符串过滤掉。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值