πCOM Execution - T1559.001
Templates and methods of quickly executing COM and DCOM
Windows Components Object Model quick execution cheatsheet
Powershell
Using Powershell with dotnet notation to quickly create a COM or DCOM instance using either CLSID or ProgID
Execution via CLSID
Execution via ProgID
DCOM Execution
Distributed COM is an extension of COM, which enables remote execution of COM among other things. Note that DCOM can also be executed Locally by specifying the loopback interface (127.0.0.1)
Rundll32
Execution via CLSID
Execution via ProgID
Execution via shell32.dll
Scriptlet Execution from Remote Server
Remote Scriptlet via INF file
Regsvr32
COM Local Scriptlet Execution
COM Scriptlet Execution from Remote Server
CMSTP
Execution via INF file that downloads and executes a scriptlet (sct)
Credit to @Amr_Thabet for the INF code
PyCOM
π οΈ
Verclsid
Execution via CLSID
Xwizard
Execution via CLSID
ATT&CK Techniques in this Page
Command and Scripting Interpreter: PowerShell - T1059.001
Inter-Process Communication: Component Object Model - T1559.001
System Binary Proxy Execution: CMSTP - T1218.003
System Binary Proxy Execution: Rundll32 - T1218.011
System Binary Proxy Execution: Verclsid - T1218.012
System Binary Proxy Execution: Regsvr32 - T1218.010
Last updated