data:image/s3,"s3://crabby-images/db3a6/db3a63cad285f58b26ccde1677195c2b89c76c8e" alt=""
Enumeration
nmap
已知目标开放了22,80,8089端口,扫描详细情况如下
data:image/s3,"s3://crabby-images/41ffe/41ffed0da9c86b2ef96e72ca2e25e61973a141ea" alt=""
可以看到对外开放了22,80,8089三个端口
TCP/80 SSTI
访问80端口,有一个info@doctors.htb的电子邮件,点击其他的也没有什么反应,猜测有可能需要域名访问
data:image/s3,"s3://crabby-images/a6205/a62056e7eec39dfaa8bb46a643caf45780b777eb" alt=""
在/etc/hosts中增加主机与域名
data:image/s3,"s3://crabby-images/f6757/f67571108b152e2701ead809999f23ec29e38273" alt=""
然后在浏览器中访问该域名,进入了Doctor Secure Messaging登录页面,还可以注册新用户
data:image/s3,"s3://crabby-images/a9a5f/a9a5f2d51f0be7c7e77de682dba76ae3260f9c26" alt=""
先注册一个新用户,填好信息后显示账户被创建,但是只有20分钟
data:image/s3,"s3://crabby-images/c92f5/c92f5cfae802ee749f0459b743749436f2545431" alt=""
在New Message处创建的内容会在首页显示
data:image/s3,"s3://crabby-images/9150c/9150ccd4f022581d53263146c2bf910c5332a5be" alt=""
并没有发现什么东西,但是在查看源代码发现了一个新的目录/archive
data:image/s3,"s3://crabby-images/4a84d/4a84da3d78e55e6d245ea2f38c51c97e7957c01a" alt=""
访问该页面却发现该页面是空白的,只有标题写着archive
data:image/s3,"s3://crabby-images/ef000/ef00012665bef75f36c49e29911087fa47a8cf81" alt=""
但是在查看源代码时会显示xml输出,且之前创建的message标题test也包含在xml代码中
data:image/s3,"s3://crabby-images/93641/936412d39b872194972085b0fe6756a8773a75cb" alt=""
如果用户提供的标题值未经清理,则该页面容易受到服务器端模版注入(SSTI),如果能控制一个模版变量并插入 一个payload,有可能会被传入服务器执行
https://swisskyrepo.github.io/PayloadsAllTheThings/Server Side Template Injection/中详细讲述了如何检测是否存在该漏洞
data:image/s3,"s3://crabby-images/ce70c/ce70c1c74d9aacd5bc17987edb0ef8cabec69775" alt=""
首先,创建一个新的message,让标题为${7*7}
data:image/s3,"s3://crabby-images/d3b6d/d3b6df7a02e87b27799b8be8530748eb7e771089" alt=""
可以看到该代码只是原样输出,似乎并没有被执行,按照红线走下面那条路,再次创建标题为{{7*7}}的message
data:image/s3,"s3://crabby-images/8835e/8835e9af4577b0e541cfb72162c2c2ec6c6dd23c" alt=""
这次的得到的标题并不是输入的东西,而是真的计算了7*7=49,并返回了结果,可以判断存在SSTI注入,因为成功 执行了输入,所以顺着绿色剪头,这次输入{{7*'7'}}
data:image/s3,"s3://crabby-images/ad40a/ad40af0eb5811bad51664dc48b97f66e37dbfe78" alt=""
得到了输出7次的结果,根据文章中描述,如果执行结果如上图所示,则很有可能使用的模板引擎为Jinja2
data:image/s3,"s3://crabby-images/de386/de386490618e51d4c1c38aee648f790e99fd8644" alt=""
然后找到针对该引擎模板的反弹shell脚本并修改
data:image/s3,"s3://crabby-images/65ab4/65ab4de1a01a19f866de5c8c7e11b23d6fff15ab" alt=""
在本地开启监听,然后在标题中输入以上代码,在刷新/archive页面即可得到shell
data:image/s3,"s3://crabby-images/b03fb/b03fbafc080dd4c1d8a42ac74aa21e12362212c3" alt=""
Lateral Movement
在目标系统上传linpeas来检查,先在本地开启http服务,然后将linpeas下载至目标,然后添加执行权限,最后执行
data:image/s3,"s3://crabby-images/86fa2/86fa20ed2ba8ecc0b9664ab910c0d8a5b6d4f3af" alt=""
使用linpeas,在日志中发现了一个疑似密码Guitar123,但是这根本就不是邮箱的格式
data:image/s3,"s3://crabby-images/ac0e5/ac0e5b05760c7ebd94646848f48d7b2458f9989e" alt=""
使用该密码成功登录
data:image/s3,"s3://crabby-images/229a3/229a3f5e2697bddeb93bf0eeb2b0f7026da06cd9" alt=""
Privilege Escalation
Splunk 8089
刚开始时枚举时,发现Splunk Forwarder实例正在端口8089上运行
Splunk是一种日志分析工具,用于收集、分析和可视化数据。尽管 Splunk 最初并非旨在成为 SIEM 工具,但它通常 用于安全监控和业务分析。Splunk 部署通常用于存储敏感数据,如果受到威胁,可能会为攻击者提供大量信息。 可以看到该程序以root身份运行,利用它可以使我们的权限升级,在本地克隆版本库,并输入 Python 版本漏洞利用 程序的文件夹
data:image/s3,"s3://crabby-images/07987/079875aebe546724970c6195c6a1f4cc78579524" alt=""
运行脚本,返回未认证
data:image/s3,"s3://crabby-images/4e2d4/4e2d48bd707ecd0730eaa233b17f89e5f54fc4d4" alt=""
再次尝试使用刚刚获取的shaun:Guitar123来利用脚本,显示已经成功执行了指令
data:image/s3,"s3://crabby-images/73c28/73c2848698e2df8f0dc08ccde07c3b55655d18bb" alt=""
在kali中开启监听,然后执行一个反向shell
data:image/s3,"s3://crabby-images/2f06d/2f06d283450726e8bc9e8818d6c50730c4fcbfe9" alt=""
最终成功得到了一个shell,拥有root权限
data:image/s3,"s3://crabby-images/3d85e/3d85ec74d00d3d50c2597fd3cd347d44201b53e6" alt=""