本文主要是介绍HACKTHEBOX——Curling,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
data:image/s3,"s3://crabby-images/30968/309684bad6cd00ddad05cb0fef43738c9859780e" alt=""
nmap
还是老规矩,先扫描目标对外开放端口情况,只发现了22和80端口对外开启
nmap -sV -sC -oA nmap 10.10.10.150
data:image/s3,"s3://crabby-images/7968f/7968f21841ce3e3c71a01d7cec542028538e16e0" alt=""
http
80端口对外开启,从扫描结果来看好像运行着Joomla,所以先访问看看,可以看到帖子由super user撰写,且其中一篇帖子末尾署名为Floris,有可能和用户名有关
data:image/s3,"s3://crabby-images/45e22/45e22b1352d9f3de234aa2dfa7592b26c8ee9a8f" alt=""
在网页源代码最下面写了一个txt文件名
data:image/s3,"s3://crabby-images/e07cd/e07cdd5fdda16afec3e9c3c831f062d03c28556b" alt=""
很可能可以访问该文件,然后获取一些信息,通过访问该路径,获取到了一段代码
data:image/s3,"s3://crabby-images/c4d23/c4d23b54c39dc9d0fd719bf234decbe17127ce74" alt=""
编码有16位,很像base64编码,尝试对其进行解码,得到了以下结果
data:image/s3,"s3://crabby-images/410ed/410edf5b9a859aa22db06f945179f5e2501474b8" alt=""
字符串的结构挺像密码的,尝试使用floris/Curling2018!登录系统,但是遗憾的是登陆并不成功,尝试扫描网站目录,看看是否有新的发现
gobuster
gobuster dir -u http://10.10.10.150/ -w /usr/share/wordlists/dirb/small.txt -o gobuster
使用以上命令扫描得到很多路径
data:image/s3,"s3://crabby-images/aac90/aac90b4ad0bdbc6e51228c7ed637016762dc6d70" alt=""
/administrator
这个路径是一个登录表单,使用floris/Curling2018!成功登录系统
data:image/s3,"s3://crabby-images/52d70/52d70296208b2c250f924979ae5c7c39369ed4b6" alt=""
在templates中找到可以上传代码的地方,点击下图中Beez3 Details and Files
data:image/s3,"s3://crabby-images/bb51b/bb51b3a181f63cb2a5163740d840147bedd5bce3" alt=""
在其中随便选取了一个页面,修改其中的代码为php pentestmonkey的代码,然后保存
data:image/s3,"s3://crabby-images/a0331/a03314629b91f8826a17a0bb7a6f90565baf865d" alt=""
getshell
在kali中使用nc监听9091端口,然后在浏览器中运行该页面,即可将shell反弹至kali
nc -lvnp 9001
data:image/s3,"s3://crabby-images/10955/1095532da732d65d8764744db4362531bd4749e8" alt=""
接着用python3 -c 'import pty; pty.spawn("/bin/bash")'获取一个交互式shell,我们已经得到了www-data权限的shell,接下来就是想办法提权,拿flag了
www-data
在floris目录下发现了一个密码备份
data:image/s3,"s3://crabby-images/d5024/d50245a80d6620f0b042bfe91be4d82013e4424f" alt=""
尝试打开该文件,发现一大串16进制,尝试使用cyberchef进行解码
data:image/s3,"s3://crabby-images/ec36a/ec36a8e95382e0164f17b7b0ba5178bd7c109488" alt=""
首先使用from hexdump处理那些16进制字符,处理后在使用detect file type判断输出的类型,得到Bzip2则可根据文件类型执行下一步解压操作
data:image/s3,"s3://crabby-images/c8e98/c8e988cc9a40ca695a1527d90832dd124fdc8223" alt=""
我们已经知道输出文件类型为Bzip2了,接下来导入Bzip2 Decompress模块,即可解压Bzip2,然后发现现在文件类型为Gzip
data:image/s3,"s3://crabby-images/4e350/4e350f5aa7944954b6c72362465cb17e94d30369" alt=""
然后一步一步来,知道最后得到文件内容,因为在floris路径下,判断其为floris的密码
data:image/s3,"s3://crabby-images/a1a35/a1a356c4bf0a1cc552c5171202c6fea0808b5095" alt=""
floris
使用获得的密码可以很顺利的切换至floris用户
data:image/s3,"s3://crabby-images/d9c58/d9c588e6e52cf38545fa76f3a0a700d35c01a326" alt=""
然后可以顺利查看user的flag
data:image/s3,"s3://crabby-images/d9fc0/d9fc0f93e965541e418fc3751c791c58766e9c1f" alt=""
还可以进入刚才无法进入的admin-area
data:image/s3,"s3://crabby-images/92ec7/92ec7ff75f968e55356c3c3eaaafc669135f5d20" alt=""
查看input和report,猜测是调用input然后执行后得到了一个report,尝试查看计划工作cron
data:image/s3,"s3://crabby-images/aedd2/aedd26f6ccc82f02213bffc841a24c86db0a0a0e" alt=""
pspy
pspy是一个命令行工具,可以在没有root权限的情况下,监控linux进程,可以利用该工具查看其他用户的计划工作(cron job)
在kali中开启一个http服务,然后在目标系统中进行下载,添加权限,并且运行
data:image/s3,"s3://crabby-images/c4d3d/c4d3dd761732c3a19941b2525480f8d784f66fff" alt=""
查看扫描结果,发现下列结果
data:image/s3,"s3://crabby-images/8e586/8e586acf6f6959e0dcd98e3a8bacd41754eeb610" alt=""
检索发现curl的两个参数意思
-K, --config <file> Read config from a file
-o, --output <file> Write to file instead of stdout
所以在input文件中写入配置,然后计划任务执行后,就会将结果输出到report中
data:image/s3,"s3://crabby-images/bdb77/bdb77d9ec4085d5f020838d95c339b5bd886fefa" alt=""
等待计划工作执行后,即可查阅flag
data:image/s3,"s3://crabby-images/1e96e/1e96efc77c5ca7cb4491220d9c4f069fcb38c513" alt=""
sudoers
查阅他人writeup时,发现一个有趣的,先贴地址https://hipotermia.pw/htb/curling
input中写入地址,cron工作会去读取地址内容然后输出到report,按照这个思路,我们可以写一个配置,让机器去读取,之后输出到/etc/sudoers中,即可使用sudo命令切换至root用户
首先,先在kali中写一个配置
data:image/s3,"s3://crabby-images/ede8c/ede8c45fc7cbc4d6de21447904dd8429ffd332a3" alt=""
然后编辑input配置内容,机器可以请求文件中url,将配置在输出到/etc/sudoers中
data:image/s3,"s3://crabby-images/daf9b/daf9b540bb391c85c15daba917e363a5c3af26e3" alt=""
如此,便可floris便可以使用sudo命令,切换至root用户
data:image/s3,"s3://crabby-images/be2b4/be2b465d10e0ed0c498ded08159b81529d806850" alt=""
本来还可以尝试一下dirty socks,但是不知道怎么搞的,靶标的snap版本升高了,所以,暂时先放下吧,over!
data:image/s3,"s3://crabby-images/8700c/8700caec72c046bfe9a40482ffc034710d715d8b" alt=""
这篇关于HACKTHEBOX——Curling的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!