- Symfonos1 下载地址:https://www.vulnhub.com/entry/symfonos-1,322/
Symfonos1 是 Symfonos 系列靶机的第一关。
目录
1、扫描
- Netdiscover
- Nmap
2、枚举
- SMB 共享目录
- WPScan
3、漏洞利用
- 利用 WordPress 的 LFI 漏洞
- 通过 SMTP 日志投毒使 LFI 漏洞来实现 RCE
4、提权
- 利用环境变量
PATH
Let's get it!
使用 netdiscover
命令来发现目标主机,这里靶机的 IP
是 192.168.166.201
- netdiscover -i eth0
data:image/s3,"s3://crabby-images/e9e15/e9e15ad436173d4042f66e20f1807f10c32c8d55" alt=""
使用 nmap
对靶机进行端口扫描,发现开放了以下端口:22
、25
、80
、139
、445
data:image/s3,"s3://crabby-images/73fe5/73fe5d5526c9c080683991deefcba617ff3478eb" alt=""
接着使用使用 enum4linux
对靶机进行网络枚举,发现靶机存在一个名为 helios
的用户,以及两个 Samba 共享目录 /anonymous
和 /helios
data:image/s3,"s3://crabby-images/2c479/2c479d0f2eb96103cc60d0ee442cd0cba6fa9d9f" alt=""
访问 Samba 共享目录:
data:image/s3,"s3://crabby-images/e4d6f/e4d6f00201bd5965061b1fb54dbe454b64093a09" alt=""
data:image/s3,"s3://crabby-images/5208c/5208c059d681b587f129489be3a0f0afedd8f252" alt=""
先访问 /anonymous
目录,因为该目录无须输入密码即可访问:
data:image/s3,"s3://crabby-images/51307/51307f6ee96d9fe106685ee911c17adadad0effc" alt=""
查看 attention.txt
文件的内容:
data:image/s3,"s3://crabby-images/d55c8/d55c8ab2d2f6065efe08f1c3ca883310413836ed" alt=""
上面提到几个弱密码,可用来尝试进入 /helios
目录,尝试后发现弱密码 qwerty
可进入 /helios
目录:
data:image/s3,"s3://crabby-images/866e8/866e8371b0e00bbf1749be02ff36f72e18852b6e" alt=""
发现两个文件,research.txt
和 todo.txt
,查看其内容,发现 research.txt
没啥用,todo.txt
中提到了一个目录 /h3l105
,这也许是 Web站点的路径,我们可以尝试在 Web 中访问,于是访问 http://192.168.166.201/h3l105/
,发现是一个使用了 WordPress 搭建的站点:
data:image/s3,"s3://crabby-images/b5500/b5500c78fc369f90bf8436f0c0295428a92a4f31" alt=""
data:image/s3,"s3://crabby-images/f8b51/f8b51fa39e7f6a2a537c241e3ca608a859327392" alt=""
对该站点使用 BurpSuite
抓包可以看到,网站前端向服务器发请求的时候,还会请求一个域名 symfonos.local
,其实该域名是就是指向靶机的 IP
,所以我们在攻击机的 /etc/hosts
文件中加上该域名的解析记录:
data:image/s3,"s3://crabby-images/66d27/66d271d0dd68de5b2174102a63c8192a68abd824" alt=""
然后使用 WPScan
对其进行扫描,加上 -ep
参数,枚举以下该站点使用的 wordpress 插件:
- wpscan --url http://symfonos.local/h3l105/ -ep
data:image/s3,"s3://crabby-images/b750c/b750cf9da8d5a34d8391c8879705f7077112935d" alt=""
发现使用了 mail-masta
和 site-editor
这两个插件,使用 searchsploit
搜索一下看有没有相应的 exp
:
data:image/s3,"s3://crabby-images/b28e1/b28e1e9567a3fac1e53a33ec901b11c92be78b3f" alt=""
可以看到 mail-masta
这个插件的 1.0
版本存在两个漏洞,这里我们利用 LFI
漏洞,将 40290.txt
下载下来:
data:image/s3,"s3://crabby-images/7f172/7f1723c25337a6d190cc16530f1203cc39f87032" alt=""
查看该文件,可看到该漏洞的 PoC
为:
http://server/wp-content/plugins/mail-masta/inc/campaign/count_of_send.php?pl=/etc/passwd
data:image/s3,"s3://crabby-images/ace80/ace80e67a90ab863085fa8fabde34bd678472b22" alt=""
可看到漏洞确实存在且可被利用:
data:image/s3,"s3://crabby-images/9fcf6/9fcf64c8ea0eae7fdcc68c4f8a979c2b65ffc11b" alt=""
因为前面端口扫描的时候,看到靶机还开放了 25
端口,该端口上运行的是 SMTP 邮件服务,所以下面我们通过 SMTP 日志投毒来使得 LFI 漏洞实现 RCE。
访问 http://192.168.166.201/h3l105/wp-content/plugins/mail-masta/inc/campaign/count_of_send.php?pl=/var/mail/helios 可看到 /var/mail/helios
文件,该邮件记录的是 helios
用户收到的邮件信息。
于是我们可以使用 telnet
通过命令行向 helios
用户发送邮件,在邮件中插入恶意的 php 代码:
data:image/s3,"s3://crabby-images/42057/420574ceceab4dd7aa0a76104d4d414907caf847" alt=""
发送后,通过访问 http://192.168.166.201/h3l105/wp-content/plugins/mail-masta/inc/campaign/count_of_send.php?pl=/var/mail/helios&m=id 即可达到远程代码执行的效果
data:image/s3,"s3://crabby-images/1b1ae/1b1aee4589b00e3086127f377cc87cc624d9c622" alt=""
于是,用这种方式,使用 nc
命令,我们可以拿到一个反向 shell。
先监听本机 5555
端口:
data:image/s3,"s3://crabby-images/c7bfd/c7bfd15bec80dbbdbaea79c3183f9cb01e355898" alt=""
得到反向 shell:
data:image/s3,"s3://crabby-images/6e879/6e879b27f6a724a0c0ed10464b2ea53324258a21" alt=""
为了提权,我们先通过 find
命令寻找有 sticky
位的程序文件:
- find / -perm -u=s -type f 2>/dev/null
data:image/s3,"s3://crabby-images/f14b3/f14b34dda4e9d35ac5b3f6809ef27f2c29e9d4b7" alt=""
我们选择其中的 /opt/statuscheck
程序,该文件是一个二进制文件,因此我们使用 strings
命令查看它的元数据:
data:image/s3,"s3://crabby-images/ee182/ee18237ce0179b02964e3184f408eb3e9575c574" alt=""
可以看到,该程序会去调用 curl
命令。因此我们可以通过自建一个 curl
命令,并通过临时配置环境变量 PATH
,使得当 /opt/statuscheck
程序执行的时候,调用我自建的 curl
命令,从而获得一个拥有 root 权限的 shell。
依次执行下面的命令:
cd /tmp
echo "/bin/sh" > curl
chmod 777 curl
export PATH=/tmp:$PATH
echo $PATH
/opt/statuscheck
data:image/s3,"s3://crabby-images/25773/25773482358fd287a4c3e2e1aebbd46b6aeb9533" alt=""
这种提权的方式,可阅读 Linux Privilege Escalation Using PATH Variable
Hacking done.
data:image/s3,"s3://crabby-images/48c78/48c781b971342902bfa88fbc76aadca4b890eb66" alt=""
网友评论