ID | Name |
---|---|
T1003.001 | LSASS Memory |
T1003.002 | Security Account Manager |
T1003.003 | NTDS |
T1003.004 | LSA Secrets |
T1003.005 | Cached Domain Credentials |
T1003.006 | DCSync |
T1003.007 | Proc Filesystem |
T1003.008 | /etc/passwd and /etc/shadow |
Adversaries may attempt to access credential material stored in the process memory of the Local Security Authority Subsystem Service (LSASS). After a user logs on, the system generates and stores a variety of credential materials in LSASS process memory. These credential materials can be harvested by an administrative user or SYSTEM and used to conduct Lateral Movement using Use Alternate Authentication Material.
As well as in-memory techniques, the LSASS process memory can be dumped from the target host and analyzed on a local system.
For example, on the target host use procdump:
procdump -ma lsass.exe lsass_dump
Locally, mimikatz can be run using:
sekurlsa::Minidump lsassdump.dmp
sekurlsa::logonPasswords
Built-in Windows tools such as comsvcs.dll
can also be used:
Similar to Image File Execution Options Injection, the silent process exit mechanism can be abused to create a memory dump of lsass.exe
through Windows Error Reporting (WerFault.exe
).[3]
Windows Security Support Provider (SSP) DLLs are loaded into LSASS process at system start. Once loaded into the LSA, SSP DLLs have access to encrypted and plaintext passwords that are stored in Windows, such as any logged-on user's Domain password or smart card PINs. The SSP configuration is stored in two Registry keys: HKLM\SYSTEM\CurrentControlSet\Control\Lsa\Security Packages
and HKLM\SYSTEM\CurrentControlSet\Control\Lsa\OSConfig\Security Packages
. An adversary may modify these Registry keys to add new SSPs, which will be loaded the next time the system boots, or when the AddSecurityPackage Windows API function is called.[4]
The following SSPs can be used to access credentials:
ID | Name | Description |
---|---|---|
C0025 | 2016 Ukraine Electric Power Attack |
During the 2016 Ukraine Electric Power Attack, Sandworm Team used Mimikatz to capture and use legitimate credentials.[6] |
G0006 | APT1 |
APT1 has been known to use credential dumping using Mimikatz.[7] |
G0007 | APT28 |
APT28 regularly deploys both publicly available (ex: Mimikatz) and custom password retrieval tools on victims.[8][9] They have also dumped the LSASS process memory using the MiniDump function.[10] |
G0022 | APT3 |
APT3 has used a tool to dump credentials by injecting itself into lsass.exe and triggering with the argument "dig."[11] |
G0050 | APT32 |
APT32 used Mimikatz and customized versions of Windows Credential Dumper to harvest credentials.[12][13] |
G0064 | APT33 |
APT33 has used a variety of publicly available tools like LaZagne, Mimikatz, and ProcDump to dump credentials.[14][15] |
G0087 | APT39 |
APT39 has used Mimikatz, Windows Credential Editor and ProcDump to dump credentials.[16] |
G0096 | APT41 |
APT41 has used hashdump, Mimikatz, and the Windows Credential Editor to dump password hashes from memory and authenticate to other user accounts.[17][18] |
G1023 | APT5 |
APT5 has used the Task Manager process to target LSASS process memory in order to obtain NTLM password hashes. APT5 has also dumped clear text passwords and hashes from memory using Mimikatz hosted through an RDP mapped drive.[19] |
G0143 | Aquatic Panda |
Aquatic Panda has attempted to harvest credentials through LSASS memory dumping.[20] |
S0606 | Bad Rabbit |
Bad Rabbit has used Mimikatz to harvest credentials from the victim's machine.[21] |
G0108 | Blue Mockingbird |
Blue Mockingbird has used Mimikatz to retrieve credentials from LSASS memory.[22] |
G0060 | BRONZE BUTLER |
BRONZE BUTLER has used various tools (such as Mimikatz and WCE) to perform credential dumping.[23] |
C0032 | C0032 |
During the C0032 campaign, TEMP.Veles used Mimikatz and a custom tool, SecHack, to harvest credentials.[24] |
G0003 | Cleaver |
Cleaver has been known to dump credentials using Mimikatz and Windows Credential Editor.[25] |
S0154 | Cobalt Strike |
Cobalt Strike can spawn a job to inject into LSASS memory and dump password hashes.[26] |
S0046 | CozyCar |
CozyCar has executed Mimikatz to harvest stored credentials from the victim and further victim penetration.[27] |
C0029 | Cutting Edge |
During Cutting Edge, threat actors used Task Manager to dump LSASS memory from Windows devices to disk.[28] |
S0187 | Daserf |
Daserf leverages Mimikatz and Windows Credential Editor to steal credentials.[29] |
G1006 | Earth Lusca |
Earth Lusca has used ProcDump to obtain the hashes of credentials by dumping the memory of the LSASS process.[30] |
S0367 | Emotet |
Emotet has been observed dropping password grabber modules including Mimikatz. [31] |
S0363 | Empire |
Empire contains an implementation of Mimikatz to gather credentials from memory.[32] |
G1016 | FIN13 |
FIN13 has obtained memory dumps with ProcDump to parse and extract credentials from a victim's LSASS process memory with Mimikatz.[33][34] |
G0037 | FIN6 |
FIN6 has used Windows Credential Editor for credential dumping.[35][36] |
G0061 | FIN8 |
FIN8 harvests credentials using Invoke-Mimikatz or Windows Credentials Editor (WCE).[37] |
G0117 | Fox Kitten |
Fox Kitten has used prodump to dump credentials from LSASS.[38] |
G0093 | GALLIUM |
GALLIUM used a modified version of Mimikatz along with a PowerShell-based Mimikatz to dump credentials on the victim machines.[39][40] |
S0342 | GreyEnergy |
GreyEnergy has a module for Mimikatz to collect Windows credentials from the victim’s machine.[41] |
G0125 | HAFNIUM |
HAFNIUM has used |
S0357 | Impacket |
SecretsDump and Mimikatz modules within Impacket can perform credential dumping to obtain account and password information.[44] |
G0119 | Indrik Spider |
Indrik Spider used Cobalt Strike to carry out credential dumping using ProcDump.[45] |
G0004 | Ke3chang |
Ke3chang has dumped credentials, including by using Mimikatz.[46][47][48] |
G0094 | Kimsuky |
Kimsuky has gathered credentials using Mimikatz and ProcDump.[49][50][51] |
S0349 | LaZagne |
LaZagne can perform credential dumping from memory to obtain account and password information.[52] |
G0077 | Leafminer |
Leafminer used several tools for retrieving login and password information, including LaZagne and Mimikatz.[53] |
G0065 | Leviathan |
Leviathan has used publicly available tools to dump password hashes, including ProcDump and WCE.[54] |
S0681 | Lizar | |
S0121 | Lslsass |
Lslsass can dump active logon session password hashes from the lsass process.[7] |
S1060 | Mafalda | |
G0059 | Magic Hound |
Magic Hound has stolen domain credentials by dumping LSASS process memory using Task Manager, comsvcs.dll, and from a Microsoft Active Directory Domain Controller using Mimikatz.[58][59][60][61] |
S0002 | Mimikatz |
Mimikatz performs credential dumping to obtain account and password information useful in gaining access to additional systems and enterprise network resources. It contains functionality to acquire information about credentials in many ways, including from the LSASS Memory.[62][63][64][65] |
G0069 | MuddyWater |
MuddyWater has performed credential dumping with Mimikatz and procdump64.exe.[66][67][68] |
S0056 | Net Crawler |
Net Crawler uses credential dumpers such as Mimikatz and Windows Credential Editor to extract cached credentials from Windows systems.[25] |
S0368 | NotPetya |
NotPetya contains a modified version of Mimikatz to help gather credentials that are later used for lateral movement.[69][70][65] |
G0049 | OilRig |
OilRig has used credential dumping tools such as Mimikatz to steal credentials to accounts logged into the compromised system and to Outlook Web Access.[71][72][58][73] |
S0439 | Okrum |
Okrum was seen using MimikatzLite to perform credential dumping.[74] |
S0365 | Olympic Destroyer |
Olympic Destroyer contains a module that tries to obtain credentials from LSASS, similar to Mimikatz. These credentials are used with PsExec and Windows Management Instrumentation to help the malware propagate itself across a network.[75] |
C0014 | Operation Wocao |
During Operation Wocao, threat actors used ProcDump to dump credentials from memory.[76] |
G0068 | PLATINUM |
PLATINUM has used keyloggers that are also capable of dumping credentials.[77] |
S0428 | PoetRAT |
PoetRAT used voStro.exe, a compiled pypykatz (Python version of Mimikatz), to steal credentials.[78] |
S0378 | PoshC2 |
PoshC2 contains an implementation of Mimikatz to gather credentials from memory.[79] |
S0194 | PowerSploit |
PowerSploit contains a collection of Exfiltration modules that can harvest credentials using Mimikatz.[80][81] |
S0192 | Pupy |
Pupy can execute Lazagne as well as Mimikatz using PowerShell.[82] |
S0583 | Pysa | |
G0034 | Sandworm Team |
Sandworm Team has used its plainpwd tool, a modified version of Mimikatz, and comsvcs.dll to dump Windows credentials from system memory.[84][85][86] |
G0091 | Silence |
Silence has used the Farse6.1 utility (based on Mimikatz) to extract credentials from lsass.exe.[87] |
S0692 | SILENTTRINITY |
SILENTTRINITY can create a memory dump of LSASS via the |
G0027 | Threat Group-3390 |
Threat Group-3390 actors have used a modified version of Mimikatz called Wrapikatz to dump credentials. They have also dumped credentials from domain controllers.[89][90] |
C0030 | Triton Safety Instrumented System Attack |
In the Triton Safety Instrumented System Attack, TEMP.Veles used Mimikatz.[91] |
G1017 | Volt Typhoon |
Volt Typhoon has attempted to access hashed credentials from the LSASS process memory space.[92] |
G0107 | Whitefly | |
S0005 | Windows Credential Editor |
Windows Credential Editor can dump credentials.[94] |
G0102 | Wizard Spider |
Wizard Spider has dumped the lsass.exe memory to harvest credentials with the use of open-source tool LaZagne.[95] |
ID | Mitigation | Description |
---|---|---|
M1040 | Behavior Prevention on Endpoint |
On Windows 10, enable Attack Surface Reduction (ASR) rules to secure LSASS and prevent credential stealing. [96] |
M1043 | Credential Access Protection |
With Windows 10, Microsoft implemented new protections called Credential Guard to protect the LSA secrets that can be used to obtain credentials through forms of credential dumping. It is not configured by default and has hardware and firmware system requirements. It also does not protect against all forms of credential dumping.[97][98] |
M1028 | Operating System Configuration |
Consider disabling or restricting NTLM.[99] Consider disabling WDigest authentication.[100] |
M1027 | Password Policies |
Ensure that local administrator accounts have complex, unique passwords across all systems on the network. |
M1026 | Privileged Account Management |
Do not put user or admin domain accounts in the local administrator groups across systems unless they are tightly controlled, as this is often equivalent to having a local administrator account with the same password on all systems. Follow best practices for design and administration of an enterprise network to limit privileged account use across administrative tiers. |
M1025 | Privileged Process Integrity |
On Windows 8.1 and Windows Server 2012 R2, enable Protected Process Light for LSA.[101] |
M1017 | User Training |
Limit credential overlap across accounts and systems by training users and administrators not to use the same password for multiple accounts. |
ID | Data Source | Data Component | Detects |
---|---|---|---|
DS0017 | Command | Command Execution |
Monitor executed commands and arguments that may attempt to access credential material stored in the process memory of the Local Security Authority Subsystem Service (LSASS). Remote access tools may contain built-in features or incorporate existing tools like Mimikatz. PowerShell scripts also exist that contain credential dumping functionality, such as PowerSploit's Invoke-Mimikatz module,[102] which may require additional logging features to be configured in the operating system to collect necessary information for analysis. Note: Event ID 4104 from the "Microsoft-Windows-PowerShell/Operational" log captures Powershell script blocks, whose contents can be further analyzed to determine if they’re performing LSASS dumping. |
DS0022 | File | File Creation |
Monitor for the unexpected creation of memory dump files for the LSASS process (e.g., |
DS0028 | Logon Session | Logon Session Creation |
Monitor for newly constructed logon behavior from credentials being accessed by process memory of the LSASS. For example, detect behaviors of Secretsdump against a system, not being a Domain Controller. |
DS0009 | Process | OS API Execution |
Monitor for API calls that may attempt to access credential material stored in the process memory of the Local Security Authority Subsystem Service (LSASS). OS API calls associated with LSASS process dumping include Note: Most EDR tools do not support direct monitoring of API calls due to the sheer volume of calls produced by an endpoint but may have alerts or events that are based on abstractions of OS API calls. Dynamic malware analysis tools (i.e., sandboxes) can be used to trace the execution, including OS API calls, for a single PE binary. |
Process Access |
Monitor for unexpected processes interacting with LSASS.exe.[103] Common credential dumpers such as Mimikatz access LSASS.exe by opening the process, locating the LSA secrets key, and decrypting the sections in memory where credential details are stored. Credential dumpers may also use methods for reflective Process Injection to reduce potential indicators of malicious activity. Usage of Procdump and Windows Task Manager for LSASS dumping can also be detected via process creation events, since they both have a predictable set of command-line arguments (i.e., for specifying the process to be dumped). Note: Sysmon process access events (Event ID 10) can be extremely noisy, which necessitates tweaking the Sysmon configuration file. We recommend taking an approach analogous to that of the Sysmon Modular Configuration project (https://github.com/olafhartong/sysmon-modular) and filtering out any benign processes in your environment that produce large volumes of process access events. The GrantedAccess value in the below analytic for Mimikatz is meant to be used solely as an illustrative example of detecting Mimikatz LSASS access. However, actual GrantedAccess values change over time with different versions of Mimikatz and therefore detection engineers need to verify the accuracy of any GrantedAccess values that their analytics are using. Analytic 1 - Mimikatz
Analytic 2 - Procdump
Analytic 3 - Windows Task Manager
|
||
Process Creation |
Monitor for newly executed processes that may be indicative of credential dumping. On Windows 8.1 and Windows Server 2012 R2, monitor Windows Logs for LSASS.exe creation to verify that LSASS started as a protected process. Try monitoring for Sysmon Event ID 1 and/or Windows Security Event ID 4688 for process activity. Note: - Rundll32/MiniDump has a different command-line syntax than that of Procdump, in that the process being dumped is specified via process ID instead of name (as with Procdump). Therefore, because the LSASS process ID is non-deterministic, the MiniDump detection isn’t specific to LSASS dumping and may need to be tuned to help reduce false positives.- When monitoring for .dll functions on the command-line be sure to also check for the ordinal associated with the function. Analytic 1 - Procdump
Analytic 2 - MiniDump via rundll32
|
||
DS0024 | Windows Registry | Windows Registry Key Modification |
Monitor for changes to Registry entries associated with credential access that is stored in the process memory of the LSASS. For example, the adversary can modify the SAM and SYSTEM files. |