Vulnhb 靶场系列:Jarbas1.0
靶场镜像
信息收集
攻击机kali IP地址
data:image/s3,"s3://crabby-images/6d51b/6d51b856e8574fbdcd679153473dc8d12febb9db" alt=""
通过nmap 进行主机发现,发现目标机IP地址
nmap -sP 192.168.227.1/24
data:image/s3,"s3://crabby-images/1ff58/1ff589591f4bd1ed28c811965bf6efad94fa7b0d" alt=""
参数说明:
-sP (Ping扫描)
该选项告诉Nmap仅仅 进行ping扫描 (主机发现),然后打印出对扫描做出响应的那些主机。 没有进一步的测试 (如端口扫描或者操作系统探测)。 这比列表扫描更积极,常常用于 和列表扫描相同的目的。它可以得到些许目标网络的信息而不被特别注意到。 对于攻击者来说,了解多少主机正在运行比列表扫描提供的一列IP和主机名往往更有价值。
确定下来目标机的主机信息后,通过nmap 探测目标机的服务信息及开放的端口信息
nmap -A 192.168.227.139
data:image/s3,"s3://crabby-images/3acf8/3acf8be75d3f65750cb7428582a0c9c48e6a3d53" alt=""
可以看到开放了web 服务80端口和8080端口,首先访问一下80端口
data:image/s3,"s3://crabby-images/27016/270168cac326676cc7e17f2c62dc62b55e5984fb" alt=""
没有发现什么有用信息,进一步探测一下web 目录,这里使用kali 下的dirb,指定类型为html文件
dirb http://192.168.227.139/ -X .html
data:image/s3,"s3://crabby-images/41c34/41c34234fbd2fea39b5527243753f815b1b5cf7a" alt=""
发现两个文件,访问http://192.168.227.139/access.html
data:image/s3,"s3://crabby-images/23054/230541fb1485630f96d8920907534e21aaabffc5" alt=""
发现三组MD5加密的账号密码,解密之
data:image/s3,"s3://crabby-images/c90ed/c90ed7c9e11c792db06b2087a05b714c91a41971" alt=""
尝试用这三组账号密码登录ssh和mysql,发现并不能登录
data:image/s3,"s3://crabby-images/00987/0098786b20545fdd53b7e5252a1fcadb8d0a1382" alt=""
访问8080端口
data:image/s3,"s3://crabby-images/ebe00/ebe00ec0742b5ae0d1b889a352f9fbdd6cceeac1" alt=""
尝试登录,发现第三组账号密码成功登录
data:image/s3,"s3://crabby-images/32843/32843e9c38d78758ceea62d577de5bc0f1d7e6c4" alt=""
漏洞挖掘
我们发现8080端口开放的服务,存在漏洞利用
data:image/s3,"s3://crabby-images/9263d/9263dd77491ba3a900d84f1d0251e737624a4555" alt=""
参考文档:
https://www.rapid7.com/db/modules/exploit/multi/http/jenkins_script_console
打开msfconsole,并使用漏洞exp
data:image/s3,"s3://crabby-images/2dd03/2dd03660a36eee7cced001329d5514ed625f1ed6" alt=""
设置参数
data:image/s3,"s3://crabby-images/8ee23/8ee23b655ffe69ba9d7ca81df84346caf5b3194d" alt=""
输入exploit,获取到一个meterpreter
data:image/s3,"s3://crabby-images/7ba7a/7ba7a23bad5ae718ef0b5d5c82b1d101be275811" alt=""
输入shell,获取到一个shell 会话
data:image/s3,"s3://crabby-images/59a47/59a4794f60cc306c28fbb0c31fd8abead86459f0" alt=""
也可以通过python 建立会话
python -c 'import pty;pty.spawn("/bin/bash")';
data:image/s3,"s3://crabby-images/166e0/166e08cf2836a5dc9235467cea5fcef4654ac60d" alt=""
尝试通过find 发现flag 文件,发现权限太低,几乎都没法访问
data:image/s3,"s3://crabby-images/ec386/ec3865948b2137f0ae4ab5a298f65973d1ae4cfe" alt=""
最后我们发现一个很有意思的脚本
data:image/s3,"s3://crabby-images/4a569/4a5698b7b0c98a05a171f6b99a6b2325299cc075" alt=""
data:image/s3,"s3://crabby-images/bf219/bf219a94ef53a383d18c5a00bc405863731de80f" alt=""
这个脚本每隔5分钟会清理一次http的访问日志,更重要的是这个脚本的权限是777
data:image/s3,"s3://crabby-images/c8766/c876657cc3bbdd374b1e2b0768b4355309fa175b" alt=""
提权
我们先在本地新建一个CleaningScript.sh ,用于给find 设置suid权限,可以像root用户那样启动
chmod u+s /usr/bin/find
data:image/s3,"s3://crabby-images/5c0f2/5c0f2bf23fd45602337aedc617e98240860bf36d" alt=""
参考链接:
https://blog.csdn.net/wangjia55/article/details/80858415
通过meterpreter 上传脚本到目标机
data:image/s3,"s3://crabby-images/e1eda/e1eda89c842646d1d3413ce5ac670e8d43b1ffc5" alt=""
等待5分钟进入shell
data:image/s3,"s3://crabby-images/acccd/acccd4b7966c55a00b97c38c379a5570cab1fb36" alt=""
发现find 具有了suid权限
data:image/s3,"s3://crabby-images/f7cbe/f7cbeb37fadac813a3081c14067681cb16761f2f" alt=""
这时我们就可以利用find 命令的exec 功能以root 权限执行其他命令了
data:image/s3,"s3://crabby-images/6023f/6023fc3d793685996f25da7ddad0503b6919d085" alt=""
参考链接:
https://blog.csdn.net/hongrisl/article/details/83018536
最后我们就可以查找root 下是否有flag 文件了
data:image/s3,"s3://crabby-images/f3b27/f3b27f98b29670bf43968ef727e5e028b29ed3f3" alt=""
并成功读取flag文件
data:image/s3,"s3://crabby-images/117ea/117ea9a2d1689acbd87adc2c7a7488fe829f1785" alt=""
data:image/s3,"s3://crabby-images/4d394/4d39494a73b6c5e2297353a2a2a61a2d458a60ad" alt=""
另一种提权方法
同样先获取到meterpreter 权限,本地新建脚本CleaningScript.sh ,用于给cp 设置suid 的权限
chmod u+s /usr/bin/cp
data:image/s3,"s3://crabby-images/46a59/46a59b59c0c658ee3fbc7ba0ed5592f841147b23" alt=""
通过meterpreter上传,然后在目标机通过cat 查看/etc/passwd
data:image/s3,"s3://crabby-images/3bb1c/3bb1c0d4341525de115c6b9a3afe8c82bd65c449" alt=""
把文件内容复制下来,在本地新建passwd 粘贴内容,并创建一个具有root 权限的新用户
data:image/s3,"s3://crabby-images/48569/48569834fc56389533b5f9df079ac1e01e126bdf" alt=""
用户密码可以通过openssl 生成
data:image/s3,"s3://crabby-images/e8d7d/e8d7de4c701fdbb1b5eee32e082af5699f3f81d2" alt=""
通过meterpreter 上传到目标机/tmp 目录下
data:image/s3,"s3://crabby-images/dff8b/dff8b38ffa4749b9560b79344174c09154b732df" alt=""
通过咱们设置好的cp 命令覆盖原先的/etc/passwd
data:image/s3,"s3://crabby-images/3c9fe/3c9fe323f9901f055ce8a86a9b49a36280afe822" alt=""
su 切换到咱们创建的用户,成功获取到root 权限
data:image/s3,"s3://crabby-images/c98c6/c98c655398c7c2c165deab8f6799fe1bfe89a042" alt=""
另另一种提权方法
首先在本地通过msfvenom 生成一个反弹shell
data:image/s3,"s3://crabby-images/38d47/38d47a6765a2538f153d9f89f1c77250683a6a23" alt=""
在本地写入CleaningScript.sh
data:image/s3,"s3://crabby-images/2eee7/2eee760cfc90c8f00e3a5aa750c2584d99bef29a" alt=""
通过meterpreter 上传到目标机
data:image/s3,"s3://crabby-images/08e5f/08e5f076f6d4ae9910bfd1c65a6338534621914a" alt=""
在kali 开启监听
data:image/s3,"s3://crabby-images/6c5fb/6c5fb3c8ae2760e3de9378624fe184accc251b80" alt=""
等待5分钟后,获取到一个root权限反弹shell
data:image/s3,"s3://crabby-images/2b7be/2b7be77ef9ed3f26631254a2a11202a8104696b3" alt=""
data:image/s3,"s3://crabby-images/9b7af/9b7af5fab6e2dd9821e8d1f282715ac074bb0c3f" alt=""
欢迎访问阿威的博客 https://www.cnblogs.com/TWX521/ 专注技术与交流,stay hungry stay foolish
data:image/s3,"s3://crabby-images/bbc15/bbc155f257b0edd6b746a9c29081ac0b66b87201" alt=""