Attacking SAM
See Windows credentials storage.
Dumping SAM Locally
1. Copying SAM Registry Hives
There are three registry hives that we can copy if we have local admin access on the target; each will have a specific purpose when we get to dumping and cracking the hashes.
Registry Hive | Description |
---|---|
hklm\sam |
Contains the hashes associated with local account passwords. We will need the hashes so we can crack them and get the user account passwords in cleartext. |
hklm\system |
Contains the system bootkey, which is used to encrypt the SAM database. We will need the bootkey to decrypt the SAM database. |
hklm\security |
Contains cached credentials for domain accounts. We may benefit from having this on a domain-joined Windows target. |
Launching CMD as an admin will allow us to run reg.exe to save copies of the registry hives.
Transfer the registry hives to our attacker machine, for instance, with smbserver.py from impacket.
2. Dumping Hashes with Impacket's secretsdump.py
Secretsdump dumps the local SAM hashes and would've also dumped the cached domain logon information if the target was domain-joined and had cached credentials present in hklm\security.
The first step secretsdump executes is targeting the system bootkey before proceeding to dump the LOCAL SAM hashes. It cannot dump those hashes without the boot key because that boot key is used to encrypt & decrypt the SAM database.
Most modern Windows operating systems store the password as an NT hash. Operating systems older than Windows Vista & Windows Server 2008 store passwords as an LM hash, so we may only benefit from cracking those if our target is an older Windows OS. Knowing this, we can copy the NT hashes associated with each user account into a text file and start cracking passwords.
3. Cracking Hashes with Hashcat
Dumping SAM Remotely
With CrackMapExec
With access to credentials with local admin privileges, it is also possible for us to target LSA Secrets over the network.