Vulnversity-练习
本文相关内容:练习主动侦察(信息收集)、针对web应用程序进行攻击以及执行权限提升。
TryHackMe实验房间链接:https://tryhackme.com/room/vulnversity
介绍
通过本关卡,可以练习主动侦察(信息收集)、网络应用程序攻击和权限提升相关知识点。
端口扫描
Nmap 是一个免费、开源和强大的工具,用于发现计算机网络上的主机和服务。在我们的示例中,我们使用 nmap 扫描目标机器,以识别在特定端口上运行的所有服务。Nmap 有很多功能,下面总结了它提供的一些常用功能。
对目标机进行端口扫描:
答题卡:
目录扫描
目标机开启了web服务,我们用GoBuster 来对网站目录进行扫描,尝试找到一个能够上传shell文件的目录。
GoBuster 是一个用于暴力破解URI (目录和文件)、 DNS 子域名和虚拟主机名的工具,你可以在kali的/usr/share/wordlists目录下寻找默认的爆破字典使用。
GoBuster的dir模式常用参数:
使用一个 wordlist 运行 GoBuster:
答题卡
获取web服务器权限
现在我们已经找到一个可以上传文件的表单页面,我们可以在该页面上传和执行我们的payload,尝试获取web服务器的权限。
我们尝试上传一个php文件结果被网站拦截,为了确定有哪些扩展名的文件不会被阻止上传,我们将对上传表单进行fuzz处理。
打开burpsuite,使用Intruder 模块(用于自动化定制攻击),首先,创建一个扩展名字典,命名为phpex.txt,内容如下(此处也可使用seclists项目的Fuzz类字典):
确保 BurpSuite 被配置为拦截所有浏览器流量,上传一个文件,一旦这个请求被捕获,将其发送给Intruder模块,并选择“Sniper”攻击类型;
在“Positions”选项界面,找到文件名并选中扩展名,点击"Add §"按钮;
进入Payloads选项,配置好刚才创建的扩展名字典,并禁用编码选项;
最后运行攻击即可:
我们已经找到可以用于上传的文件扩展名.phtml(它返回的结果长度最短,因为没有报错信息),我们现在尝试上传一个php的反向shell文件,修改php文件内容中的ip为攻击机ip,将文件命名为shell.phtml,并上传该文件到目标站点。
此处使用的反向shell文件下载链接:https://github.com/pentestmonkey/php-reverse-shell/blob/master/php-reverse-shell.php
上传成功之后,在攻击机设置一个netcat监听器,监听的端口为反向shell文件内容中的端口,在目标网站上找到反向shell文件,点击激活即可,成功在攻击机终端获得一个shell:
此处也可以通过cat /etc/passwd,查看用户的账户信息(一般是直接找/home目录):
答题卡
权限提升
现在尝试升级权限到root用户权限。
在 Linux 中,SUID (执行时会设置所有者userId)是授予文件的一种特殊类型权限,SUID 为用户提供临时权限,允许用户在文件所有者的权限下运行程序/文件。
例如,用于更改你的密码的二进制文件上设置了 SUID 位(/usr/bin/passwd),这是因为要更改你的密码,需要写入你无权访问的shadow文件,而一般只有root 用户有这个权限对shadow文件进行写入,因此该文件需要暂时具有 root 权限来完成密码更改(所以有必要给这个文件设置SUID位)。
在目标系统上搜索所以SUID文件:
systemctl 是用于控制systemd初始化服务的工具,在 systemctl 上启用 setuid 是不正常的,使用GTFOBins,查找SUID可执行文件的利用方法:https://gtfobins.github.io/
先获得一个更稳定的shell:
修改一下上图所提供的脚本,然后在目标机的低权限shell上运行:
systemctl参考手册:https://www.freedesktop.org/software/systemd/man/systemctl.html
上述脚本已经以root身份给/bin/sh加上了s权限,现在运行sh命令(-p用于保持sh获得的权限)即可获得root权限:
答题卡
最后更新于