DCOM Exec
Last updated
Last updated
学习和实践 AWS 黑客技术:HackTricks 培训 AWS 红队专家 (ARTE) 学习和实践 GCP 黑客技术:HackTricks 培训 GCP 红队专家 (GRTE)
有关此技术的更多信息,请查看原始帖子 https://enigma0x3.net/2017/01/05/lateral-movement-using-the-mmc20-application-com-object/
分布式组件对象模型 (DCOM) 对象为基于网络的对象交互提供了有趣的能力。微软为 DCOM 和组件对象模型 (COM) 提供了全面的文档,分别可以在 这里查看 DCOM 和 这里查看 COM。可以使用 PowerShell 命令检索 DCOM 应用程序列表:
The COM对象,MMC应用程序类 (MMC20.Application),使得MMC插件操作的脚本化成为可能。值得注意的是,这个对象在Document.ActiveView
下包含一个ExecuteShellCommand
方法。关于这个方法的更多信息可以在这里找到。检查它的运行:
此功能通过DCOM应用程序促进了在网络上执行命令。要以管理员身份远程与DCOM交互,可以使用PowerShell,如下所示:
此命令连接到 DCOM 应用程序并返回 COM 对象的实例。然后可以调用 ExecuteShellCommand 方法在远程主机上执行进程。该过程涉及以下步骤:
检查方法:
获取 RCE:
有关此技术的更多信息,请查看原始帖子 https://enigma0x3.net/2017/01/23/lateral-movement-via-dcom-round-2/
MMC20.Application 对象被识别为缺乏明确的 "LaunchPermissions",默认为允许管理员访问的权限。有关更多详细信息,可以在 这里 探索一个线程,并建议使用 @tiraniddo 的 OleView .NET 来过滤没有明确启动权限的对象。
两个特定对象 ShellBrowserWindow
和 ShellWindows
因缺乏明确的启动权限而被强调。HKCR:\AppID\{guid}
下缺少 LaunchPermission
注册表项表示没有明确的权限。
对于缺乏 ProgID 的 ShellWindows
,.NET 方法 Type.GetTypeFromCLSID
和 Activator.CreateInstance
通过其 AppID 促进对象实例化。此过程利用 OleView .NET 检索 ShellWindows
的 CLSID。一旦实例化,可以通过 WindowsShell.Item
方法进行交互,从而调用方法,如 Document.Application.ShellExecute
。
提供了示例 PowerShell 命令以实例化对象并远程执行命令:
侧向移动可以通过利用 DCOM Excel 对象来实现。有关详细信息,建议阅读 Cybereason's blog 上关于通过 DCOM 利用 Excel DDE 进行侧向移动的讨论。
Empire 项目提供了一个 PowerShell 脚本,演示了通过操纵 DCOM 对象利用 Excel 进行远程代码执行 (RCE)。以下是来自 Empire's GitHub repository 的脚本片段,展示了滥用 Excel 进行 RCE 的不同方法:
两个工具被强调用于自动化这些技术:
Invoke-DCOM.ps1:由Empire项目提供的PowerShell脚本,简化了在远程机器上执行代码的不同方法的调用。该脚本可以在Empire GitHub存储库中访问。
SharpLateral:一个用于远程执行代码的工具,可以使用以下命令:
Powershell 脚本 Invoke-DCOM.ps1 允许轻松调用所有评论中提到的在其他机器上执行代码的方法。
你也可以使用 SharpLateral:
学习和实践 AWS 黑客技术:HackTricks 培训 AWS 红队专家 (ARTE) 学习和实践 GCP 黑客技术:HackTricks 培训 GCP 红队专家 (GRTE)