前言
利用sudo利用Linux的网络命名空间(network namespace)功能来提供更好的网络隔离和管理,在命名空间运行命令中或创建网络接口,当用户在sudoers文件中被授予了执行ip
和/bin/sh
命令的权限,可利用这种方式方式提升权限。
信息搜集
探测存活主机,扫描端口
data:image/s3,"s3://crabby-images/bef37/bef377cbbb5f13e8b7d2beca0b6dec73dc269cbc" alt=""
端口开放22 80,查看应用
data:image/s3,"s3://crabby-images/de64f/de64f4124bcdcf37c08701cc46f8a5d4d51aa41e" alt=""
http://192.168.236.234/index.htm
data:image/s3,"s3://crabby-images/50570/50570f219fe747ca05d66799ddd92816218b5ffa" alt=""
查看源码
data:image/s3,"s3://crabby-images/a60d2/a60d2f4b5a5aae7b352b68a160e6f31d04f18902" alt=""
提示secret.php
提交方式为GET,且字段name
=HackMyVM
,构造payload
data:image/s3,"s3://crabby-images/5f9b7/5f9b77d15de39726ce0517c4ce74923260968f70" alt=""
获取shell
POST请求方式为正常请求,继续测试,发现该位置存在命令执行
data:image/s3,"s3://crabby-images/fe05a/fe05ac18dee871cb227635ac173c9fd862b04e7d" alt=""
查看源码
data:image/s3,"s3://crabby-images/d2fb1/d2fb14dae03ae1098e0a9360020a0e8a5f297c6a" alt=""
发现了疑似隐藏的用户名以及密码,因为前期信息搜集存在22端口,尝试登录
data:image/s3,"s3://crabby-images/58380/583809b4805d62bf994d84299a757777af3639ce" alt=""
获取到flag1
权限提升
sudo -l
data:image/s3,"s3://crabby-images/6f801/6f801d6d77f549e51e49533ee02f3eec052e7d11" alt=""
发现/bin/ip的权限为root权限
data:image/s3,"s3://crabby-images/a1b25/a1b25881b9b32ceb0aa0eb422e91ab61ff8e17e4" alt=""
sudo ip netns add foo
sudo ip netns exec foo /bin/sh
data:image/s3,"s3://crabby-images/c9805/c98051de7381e23a1c202680c309e35e250b076f" alt=""
成功提权获取flag2