作者:缘来是你明 | 来源:互联网 | 2024-11-17 20:50
Vulnhub DC3 实战记录与分析
data:image/s3,"s3://crabby-images/74119/74119769b6a366a921470253f41723153832f9be" alt="技术图片"
经验与总结
平时应多积累漏洞知识,临时搜索时也要多方面搜集信息。尽管 Metasploit 中有针对 Joomla 3.7 的 RCE 工具,但其适用范围有限。此次实践中,我们通过 sqlmap 成功获取了后台密码。
深入研究 CMS 框架如 Joomla,了解其模板和脚本编写机制,有助于提高渗透测试效率。
靶机可能会因自动更新而导致 web 服务故障,这是常见的问题,需提前做好预防措施。
内核提权漏洞风险较大,建议将其作为最后的手段。本次测试中,首次尝试内核提权时导致靶机崩溃。
使用 sqlmap 时,可以通过 -C 参数指定需要 dump 的字段,提高数据提取的精确性。
除了 hashcat,John the Ripper 也是一个强大的密码破解工具,能够自动识别哈希类型。
使用 hashid 识别哈希字符串时,建议使用单引号以避免转义问题。
步骤详细记录
1. 使用 netdiscover 工具探测靶机 IP 地址为 192.168.1.104。
2. 使用 nmap 进行端口扫描,确认开放的端口为 80。
data:image/s3,"s3://crabby-images/c0309/c03097590bb37d64b2871b953875349c230004e8" alt="技术图片"
3. 访问 web 页面,初步了解目标网站。
data:image/s3,"s3://crabby-images/76313/763133d750265dd9d5d91bd6fcc3dcdec51c6f1c" alt="技术图片"
4. 使用 whatweb 扫描工具,确认网站框架为 Joomla。
data:image/s3,"s3://crabby-images/20827/20827ca47648f01aa482833a2b907dbfb6360357" alt="技术图片"
5. 使用 dirb 工具扫描网站路径,获取更多有用信息。
data:image/s3,"s3://crabby-images/ddb86/ddb862b86503018721878d9ccc6c390ef3fee587" alt="技术图片"
6. 使用 JoomScan 扫描工具,确认 Joomla 版本为 3.7.0。
data:image/s3,"s3://crabby-images/674c6/674c6770b721daa8a6756ed43dafb44d9b1d09b2" alt="技术图片"
7. 使用 searchsploit 工具查找 Joomla 3.7.0 的已知漏洞。
data:image/s3,"s3://crabby-images/b3db5/b3db5191809bd31ee0799008a9585dbed51646dc" alt="技术图片"
8. 尝试使用 Metasploit 中的 RCE 模块,但因版本不匹配或无法利用而失败。
data:image/s3,"s3://crabby-images/1b6d2/1b6d22c4bca9dc70f7f4740a8cdf1ea09cc7d529" alt="技术图片"
9. 通过 POC 验证 SQL 注入漏洞的存在(靶机因自动更新问题,重新导入后 IP 变更为 192.168.1.101)。
http://192.168.1.101/index.php?option=com_fields&view=fields&layout=modal&list[fullordering]=updatexml(0x23,concat(1,user()),1)
data:image/s3,"s3://crabby-images/7de3e/7de3e4ebdfb60ef3cdad8e3fc0e1bb682c75c035" alt="技术图片"
10. 使用 sqlmap 攻击,获取数据库信息。
data:image/s3,"s3://crabby-images/723f0/723f06185da3f722d908e6382df0e85122d8379a" alt="技术图片"
11. 获取数据库名和表名。
data:image/s3,"s3://crabby-images/da068/da0689cf24b76c626f879242e03862123d4673a5" alt="技术图片"
12. 使用 sqlmap 命令 dump users 表中的 id、username 和 password 字段。
data:image/s3,"s3://crabby-images/83e2a/83e2a2cdb871b425adfa503aa09e861a759607e9" alt="技术图片"
13. 使用 John the Ripper 破解密码。
data:image/s3,"s3://crabby-images/10ea1/10ea1e563cfc0e14048711a7da778e75d32e5e3d" alt="技术图片"
14. 使用破解后的密码登录后台管理页面。
15. 利用模板管理功能添加一个 PHP 页面,部署回连脚本。
data:image/s3,"s3://crabby-images/d01f5/d01f5bcc7936ec9a94c97cb21281a09fd7b84f7e" alt="技术图片"
16. 访问 http://192.168.1.101/templates/beez3/html/shell.php,成功获取回连 shell。
data:image/s3,"s3://crabby-images/a51c8/a51c8040ff40bb4a5f998cbcb4295e6ad503cc90" alt="技术图片"
17. 查看开放端口,确认没有 SSH 服务。
data:image/s3,"s3://crabby-images/c4fef/c4fef56f936588890c0b9a92fad236ce42375dc5" alt="技术图片"
18. 靶机再次崩溃,怀疑是自动更新问题,重新导入虚拟机并设置为 host-only 模式。
data:image/s3,"s3://crabby-images/793f5/793f55e70e677003a92faa069b3ed86c2d00b722" alt="技术图片"
19. 考虑内核提权漏洞,检查 gcc 是否可用。
data:image/s3,"s3://crabby-images/e82cf/e82cf46d4898008a34239dee101d8312539eb93f" alt="技术图片"
20. 查看内核版本。
data:image/s3,"s3://crabby-images/2ae2b/2ae2bdbf7a7ce04fe19b7f5d2f7cfb51f2b913bf" alt="技术图片"
21. 在 searchsploit 中搜索合适的提权脚本。
data:image/s3,"s3://crabby-images/b6033/b6033009598576849863c8ca1cfeaaa547482831" alt="技术图片"
22. 测试多个提权脚本,最终使用 Linux Kernel 4.4.x (Ubuntu 16.04) - 'double-fdput()' bpf(BPF_PROG_LOAD) 提权成功。
data:image/s3,"s3://crabby-images/1d967/1d9678f1e58c7580a28c52366c0fffa8d6e00ae4" alt="技术图片"
data:image/s3,"s3://crabby-images/2332e/2332e3caf3db9e3c9c5dd56e2d9b2299c59e2f65" alt="技术图片"