题目比较简单,可以利用sudo和多种suid程序提权,做个记录
进入靶场题目环境
data:image/s3,"s3://crabby-images/2d88f/2d88f9929b505a0507e0f2ba55a58eed5be824b8" alt=""
获得节点信息
data:image/s3,"s3://crabby-images/e4f43/e4f4300c467aaaf0055472deed038ac1d26f0b2e" alt=""
远程连接上
执行命令id,发现只是admin普通账户
data:image/s3,"s3://crabby-images/c9969/c996958d14cde44b69c93a28ff596e6e0d43c882" alt=""
sudo提权data:image/s3,"s3://crabby-images/f8ebf/f8ebf0b0b9aec24906102240e6ab4e44e2ae1f01" alt=""
发现存在 /usr/bin/vim, /usr/bin/bash, /usr/bin/more, /usr/bin/less, /usr/bin/nano, /usr/bin/cp, /usr/bin/awk, /usr/bin/wget, /usr/bin/su, /usr/bin/cat 多个拥有权限的应用。
其中的/usr/bin/bash可以直接执行命令,/usr/bin/su允许普通用户提升到管理员账户。
/usr/bin/bash
data:image/s3,"s3://crabby-images/de719/de719ab1ca02d67d86db186e13eb5ddef9fcddc1" alt=""
/usr/bin/su
使用exit命令退回普通用户,再使用sudo su命令可以提权到root。
data:image/s3,"s3://crabby-images/ca768/ca76810765763862b55e6d94a97b4d787ac9bf15" alt=""
suid提权
例如我们发现cat、more等命令是有root权限的,可以利用它们来读取root权限的文件
data:image/s3,"s3://crabby-images/f8ebf/f8ebf0b0b9aec24906102240e6ab4e44e2ae1f01" alt=""
data:image/s3,"s3://crabby-images/3969a/3969a5c60278028e54ee109d5284345bb059eaf8" alt=""
如果sudo -l没法用,可以使用find命令找到以后root执行权限的程序
find / -user root -perm -4000 -print 2>/dev/null
data:image/s3,"s3://crabby-images/8406b/8406b16b9b26091605c1c837f9ad75f95430668f" alt=""
PS:像find这种也是可以执行额外命令的
data:image/s3,"s3://crabby-images/ab2e6/ab2e67c89b599232b6cbd54cc81fd726340de692" alt=""