Moonraker: 1靶机练习实践报告
一、安装靶机
靶机是.ova文件,需要用VirtualBox打开,但我习惯于使用VMWare,因此修改靶机文件,使其适用于VMWare打开。
解压ova文件,得到.ovf文件和.vmdk文件。
直接用VMWare打开.ovf文件即可。
二、夺旗步骤
第一步:IP扫描,端口扫描
data:image/s3,"s3://crabby-images/bb9d7/bb9d7944e0429c76311146cc7fb958db7bbfdb30" alt=""
data:image/s3,"s3://crabby-images/0f296/0f2966e21d8fb64b63f923feb41bbadd95544ef9" alt=""
靶机IP为192.168.25.132,开放端口22(ssh),80(apache),3000(nodejs),5984(couchdb)和39847。首先爆破ssh,失败。
第二步:访问80端口、目录扫描和网站渗透测试
data:image/s3,"s3://crabby-images/d254f/d254fe3056ae704ee95a45c86610fb67ea305555" alt=""
逐个访问上述的地址,http://192.168.25.132:80/services发现一个提示。
data:image/s3,"s3://crabby-images/529cb/529cb7a310a06e0facd0d9e87576ba765086e21b" alt=""
data:image/s3,"s3://crabby-images/7c4de/7c4dec91e64715707d24f6979275d758e75957e2" alt=""
提示销售代表会查看输入的信息,可以伪造网站地址,欺骗用户点击,稍后分析。
data:image/s3,"s3://crabby-images/8a4ef/8a4ef8872cb650780075257da84ce4b8041e2a74" alt=""
data:image/s3,"s3://crabby-images/13892/138925b0d3fb78aa957c8e14a7a2ce11f784472e" alt=""
data:image/s3,"s3://crabby-images/9341d/9341db44138156a061dbf04357df8165a85cea4a" alt=""
data:image/s3,"s3://crabby-images/881cd/881cd9790d6708432470f19a03af5a2ab61e96c9" alt=""
data:image/s3,"s3://crabby-images/4f296/4f296ecb57c2cf678a6d0963cef45832f2b7e043" alt=""
有一个提示:某个地方有cookie和序列化。
然后,nikto扫描没有发现有价值信息。
第三步:整理收集到的结果,进一步分析。
启动服务器,在之前找到的http://192.168.25.132/svc-inq/sales.html地址处输入伪造的\<img src=https://img-home.csdnimg.cn/images/20230724024159.png?origin_url=”http%3A%2F%2F192.168.25.128%3A80%2Findex.html”%2F\&pos_id=img-lAQAYyo1-1716867485754)>,查看访问记录。
data:image/s3,"s3://crabby-images/2333e/2333e6f1a87a8f9790d51b38e070deece113ba91" alt=""
意外发现一个新的地址,打开地址,全站查找信息。发现一个提示用户口令的文件,在ssh和couchdb中尝试该口令,将全站出现的女性名字全部试了一遍,都不是,考点有一个提示"Google-fu.",难道是google搜索?
data:image/s3,"s3://crabby-images/103ff/103fff53cdd94c75108835f160bb6fb2d711cc73" alt=""
data:image/s3,"s3://crabby-images/2d59e/2d59e7c476c96ccb2828a1a12fc7051ca89f3fb7" alt=""
获得用户口令"jaws:dollyx99",在couchdb中成功登陆。进一步分析couchdb中的数据,发现4个新的地址,逐个访问。
data:image/s3,"s3://crabby-images/3d1c2/3d1c2e890d618522334d20a3fb7759b865f6aed1" alt=""
发现一个/HR-Confidential/offer-letters.html页面中有四个用户口令,"hugo:TempleLasersL2K ","jaws:dollyx99","holly:ArchivesPistolsL2K ","guard:FacProxsL2K"。
data:image/s3,"s3://crabby-images/50c47/50c474e582be372005e92013b4e3717723165bfc" alt=""
用这四个口令分别登陆ssh,失败,登陆couchdb,没有权限访问的两个数据库还是无法访问。继续分析/svc-inq/salesmoon-gui.php,找到另一个提示文件,提到了端口3000,提到了cookie,我们找到过一个cookie和序列化的提示,难道存在序列化漏洞?分析代码,obj.username可能存在序列化漏洞。
data:image/s3,"s3://crabby-images/eeb82/eeb822ee3c4fe5bc00d9f2ccd903a25d04ed253e" alt=""
访问3000端口,需要用户口令,用之前获得的4个口令逐个尝试,"hugo:TempleLasersL2K "成功登陆。根据提示访问/accounting/hugo-manif.mp3,什么也没发现。
data:image/s3,"s3://crabby-images/552fb/552fb1d5b0c580ff8b933ef63912c4d2b65c5ed8" alt=""
上网搜索nodejs序列化漏洞相关信息,找到一个利用脚本,直接拿来主义。
data:image/s3,"s3://crabby-images/1c648/1c648fe3df56e206865eeabf76867055700faa9f" alt=""
data:image/s3,"s3://crabby-images/f421c/f421c133ff796c759dce26658ae4f3c2705440ea" alt=""
将脚本进行base64是因为nodejs后台代码会对cookie进行base64解码,将cookie替换成shellcode,本地监听设置的端口1234.
data:image/s3,"s3://crabby-images/49ee6/49ee69f2332cf36d48ad21123b04465391e1b34e" alt=""
获得一个shell。全目录遍历查看,发现/opt/couchdb/etc/local.ini文件中又发现两个口令。同样在ssh和couchdb中尝试,还在http://102.168.25.132:3000/尝试,发现"hugo:321Blastff!"可以通过ssh登陆,获取hugo权限的shell。
data:image/s3,"s3://crabby-images/aac0e/aac0e9e09050de3ff3fac65690232d33b5670cab" alt=""
data:image/s3,"s3://crabby-images/ff2fd/ff2fd547269efacbd4895a76d7db9469c66c8631" alt=""
还是无法查看/root目录下的文件,继续搜索,在/var/mail/hugo下查看到一个信息。root用户的密码,条件反射的爆破。
data:image/s3,"s3://crabby-images/0c74b/0c74b3a7d51a62815c111d8c022cb6b8bb130543" alt=""
data:image/s3,"s3://crabby-images/48e04/48e04064b6ccab3670f615a59c42f8273742831a" alt=""
得到root用户新口令"root:cyberVR00M",登陆root用户,读取flag。
data:image/s3,"s3://crabby-images/4f587/4f587f786886d43ba796e4fdba2abeb93a18ec17" alt=""
三、总结
\1. 灵活运用之前靶机练习中学到的搭建攻击者服务器的办法
\2. 常见漏洞的脚本要备齐,此处新收集nodejs序列化漏洞利用脚本