马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?注册帐号
×
Impacket是一个Python类库,用于对SMB1-3或IPv4 / IPv6 上的TCP、UDP、ICMP、IGMP,ARP,IPv4,IPv6,SMB,MSRPC,NTLM,Kerberos,WMI,LDAP等协议进行低级编程访问。 在本文的实验场景中,我们需要准备以下两个系统: 1.配置域控的Windows服务器; 2. Kali Linux
系统相关设置如下: Windows Server域: SERVER 用户: Administrator 密码: T00r IP地址: 192.168.1.140
Kali Linux: 192.168.1.135 在正式开始使用Impacket工具之前,让我们先对目标Windows服务器执行Nmap版本扫描,以获取当前Windows Server上运行的有关服务信息。 nmap -sV 192.168.1.140
正如你在上面的截图中看到的,目标系统当前运行的服务有域服务,Kerberos服务,Netbios服务,LDAP服务和Windows RPC服务。 现在让我们从GitHub安装Impacket工具。你可以在这里获取到。 首先,我们通过git clone命令克隆存储库,然后按以下截图所示安装Impacket。 git clone https://github.com/CoreSecurity/impacket.gitcd impacket/python setup.py install
这将在你的Kali Linux上安装Impacket。安装完成后,我们来查看下Impacket中都有哪些工具。 cd impacket/examples
可以看到其中包含了许多的python脚本工具,让我们来尝试使用其中的一些工具: Ping.py一个简单的ICMP ping脚本,使用ICMP echo和echo-reply数据包检查主机状态。 ./ping.py
语法: ./ping.py [Source IP] [Destination IP] ./ping.py 192.168.1.135 192.168.1.140以下是我从192.168.1.140(Windows Server)获得的ICMP响应 Lookupsid.py通过[MS-LSAT] MSRPC接口的Windows SID bruteforcer示例,旨在查找远程用户/组。 ./lookupsid.py
语法: ./lookupsid.py [[domain/] username [: password] @] [Target IP Address] ./lookupsid.py SERVER/Administrator: T00r@192.168.1.140如下所示,lookupsid.py已成功为我提取到了目标服务器的用户和组信息 Psexec.pyPsexec.py允许你在远程Windows系统上执行进程,复制文件,并返回处理输出结果。此外,它还允许你直接使用完整的交互式控制台执行远程shell命令(不需要安装任何客户端软件)。 ./psexec.py
语法: ./psexec.py [[domain/] username [: password] @] [Target IP Address] ./psexec.py SERVER/Administrator: T00r@192.168.1.140如下所示,我获取到了目标服务器的远程shell Rpcdump.py该脚本将转储在目标上注册的RPC端点和字符串bindings列表。它也会尝试将它们与一些知名的端点进行匹配。 ./rpcdump.py
语法: ./rpcdump.py [[domain/] username [: password] @] [Target IP Address] ./rpcdump.py SERVER/Administrator: T00r@192.168.1.140如下所示,我成功获取到了目标RPC列表 
Samrdump.py 与MSRPC套件中的安全帐户管理器远程接口通信的应用程序。它将为我们列出目标系统上的用户帐户,可用资源共享以及通过此服务导出的其他敏感信息 ./samrdump.py
语法: ./samrdump.py [[domain/] username [: password] @] [Target IP Address] ./samrdump.py SERVER/Administrator: T00r@192.168.1.140如下所示,我从目标服务器提取了SAM信息 Sniff.py一个简单的数据包嗅探脚本。使用pcapy库来侦听通过指定接口传输的数据包 . /sniff.py选择正确的网卡,并开始嗅探  Sniffer.py一个简单的数据包嗅探脚本,使用原始套接字来侦听与指定协议相对应的传输数据包。 . /sniffer.py sniffer开始监听icmp, tcp和udp数据包  Wmiexec.py它会生成一个使用Windows Management Instrumentation的半交互式shell,并以管理员身份运行。你不需要在目标服务器上安装任何的服务/代理,因此它非常的隐蔽。 ./wmiexec.py
语法: ./wmiexec.py [[domain/] username [: password] @] [Target IP Address] ./wmiexec.py SERVER/Administrator: T00r@192.168.1.140如下所示,我获取到了目标服务器的shell Wmiquery.py它允许发出WQL查询并获取目标系统WMI对象的描述信息。 ./wmiquery.py
语法: ./wmiquery.py [[domain/] username [: password] @] [Target IP Address] ./wmiquery.py SERVER/Administrator: T00r@192.168.1.140这将打开一个shell,你可以在其中执行WQL查询 SELECT * FROM Win32_LogicalDisk WHERE FreeSpace < 209152 Atexec.py通过Task Scheduler服务在目标系统上执行命令,并返回输出结果。 ./atexec.py
语法: /atexec.py [[domain/] username [: password] @] [Target IP Address] [Command] ./atexec.py SERVER/Administrator: T00r@192.168.1.140 systeminfo如下所示,我与目标服务器建立了远程连接,并执行了systeminfo命令,输出结果显示在了我的Kali终端上。 getArch.py该脚本将连接目标(或目标列表上的)计算机,并使用已记录的MSRPC特征收集由(ab)安装的操作系统架构类型。 ./getArch.py
语法: ./getArch.py -target [IP Address] 命令: ./getArch.py -target 192.168.1.140 所下所示,目标系统架构为64-bit Ifmap该脚本将绑定到目标的MGMT接口,以获取接口ID列表。它将在另一个接口UUID列表的顶部使用该列表,并报告该接口是否被列出和/或处于侦听状态。 
语法: ./ifmap.py [Host IP Address] [Port] ./ifmap.py 192.168.1.140 135./ifmap.py 192.168.1.140 49154
|