基本信息
lab地址:
https://www.hackthebox.eu/home/machines/profile/219
端口扫描
data:image/s3,"s3://crabby-images/0235e/0235e40032f40eabd808c9443940bdd27ae4250d" alt=""
80端口closed,直接访问失败
8080
data:image/s3,"s3://crabby-images/7a05b/7a05b211b2a39c819f9d6759d093ccdbc55a011c" alt=""
data:image/s3,"s3://crabby-images/25e64/25e6448b0ece7e4ba2d7f5e33938f21aee091728" alt=""
提示源代码在某个目录的’SuperSecureServer.py’ 中。
扫一下目录,是develop,得到源码:
data:image/s3,"s3://crabby-images/09eff/09effb42d9f41f205e057c2fb79835f0c9c625f1" alt=""
data:image/s3,"s3://crabby-images/96853/96853ca23c2889bf87d7efcd0b3c841479e76d03" alt=""
代码注入
注意这里直接使用了exec:
data:image/s3,"s3://crabby-images/8285d/8285da91ffb073f4bd322a8a469d9cf69f9a2a0d" alt=""
直接exec我们可控的path,那么我们就可以在path注入python代码得到reverse shell
reverse shell
代码注入,得到www-root权限的shell:
data:image/s3,"s3://crabby-images/30580/3058091a40dc7012c02bd4a6bd7df83dcec3466d" alt=""
data:image/s3,"s3://crabby-images/e266c/e266c30fbdac451af673f0dc6fbb0eada3046f24" alt=""
接下来我们需要切到robert用户:
data:image/s3,"s3://crabby-images/5c26b/5c26b8aea50aed57f94d172e8c1e3dabdca808f8" alt=""
decrypt
robert用户目录存在一个加密程序,out.txt是check.txt加密后的文件, 查看下代码就知道加密算法只是异或,我们就可以用这个程序解出来key:
1 | python3 SuperSecureCrypt.py -i out.txt -o /tmp/key.txt -k "$(cat check.txt)" -d |
data:image/s3,"s3://crabby-images/0fb99/0fb999d6d8a0bc165e6a04f0b89e5d30c1a395ec" alt=""
然后使用这个key解密passwordreminder.txt:
1 | python3 SuperSecureCrypt.py -i passwordreminder.txt -o /tmp/pass.txt -k alexandrovich -d |
data:image/s3,"s3://crabby-images/3c169/3c1697527ed3590433f1a04561161ea5a5cee658" alt=""
user flag
然后使用这个密码,以robert用户登录,得到user.txt:
data:image/s3,"s3://crabby-images/ffbe7/ffbe713a554bc1a6faa39429751470c7dcf60173" alt=""
BetterSSH 条件竞争
在BetterSSH中有一个python文件,会读取shadow,把password写到tmp之后进行校验,并且有一个sleep,我们可以尝试在sleep的时候去读取tmp,条件竞争
data:image/s3,"s3://crabby-images/91ce3/91ce3e12988176c0a3eddbf97b110aeb79ced2a5" alt=""
这里我们使用两个SSH session
1 | while sleep 0.1; do cat /tmp/SSH/* 2>/dev/null; done # session 1 |
data:image/s3,"s3://crabby-images/25c39/25c39ccf20c83fcaf0d63ee7b49f642a2cf7f44f" alt=""
data:image/s3,"s3://crabby-images/fc343/fc343243722e665e89f24e5d93b21c678c99e7af" alt=""
1 | root |
解出来root密码是mercedes:
data:image/s3,"s3://crabby-images/da28f/da28f90c391dbf15856988dd9462ebc6472d5b76" alt=""
root flag
root不能直接SSH登录,使用su切换到root,得到root.txt:
data:image/s3,"s3://crabby-images/cb32e/cb32ed2538d492ad9ae8ecfc41d36ed0d0a9b7ab" alt=""
参考链接
https://github.com/Tatik07/Hackthebox/blob/master/Obscurity-Shell.py
Hackthebox Obscurity - YouTube
https://www.youtube.com/watch?v=0qXFSkPeNuo