External Forest Domain - One-Way (Outbound)
In diesem Szenario vertraut Ihre Domäne bestimmte Privilegien einem Prinzipal aus anderen Domänen an.
Enumeration
Ausgehendes Vertrauen
Vertrauenskonto-Angriff
Eine Sicherheitslücke besteht, wenn eine Vertrauensbeziehung zwischen zwei Domänen hergestellt wird, die hier als Domäne A und Domäne B identifiziert sind, wobei Domäne B ihr Vertrauen auf Domäne A ausdehnt. In diesem Setup wird ein spezielles Konto in Domäne A für Domäne B erstellt, das eine entscheidende Rolle im Authentifizierungsprozess zwischen den beiden Domänen spielt. Dieses Konto, das mit Domäne B verbunden ist, wird zum Verschlüsseln von Tickets für den Zugriff auf Dienste in den Domänen verwendet.
Der entscheidende Aspekt hier ist, dass das Passwort und der Hash dieses speziellen Kontos mithilfe eines Befehlszeilentools von einem Domänencontroller in Domäne A extrahiert werden können. Der Befehl zum Ausführen dieser Aktion lautet:
Diese Extraktion ist möglich, da das Konto, das mit einem $ nach seinem Namen identifiziert ist, aktiv ist und zur Gruppe "Domänenbenutzer" der Domäne A gehört, wodurch Berechtigungen, die mit dieser Gruppe verbunden sind, vererbt werden. Dies ermöglicht es Personen, sich gegen die Domäne A mit den Anmeldeinformationen dieses Kontos zu authentifizieren.
Warnung: Es ist möglich, diese Situation auszunutzen, um in der Domäne A als Benutzer Fuß zu fassen, wenn auch mit eingeschränkten Berechtigungen. Dieser Zugriff ist jedoch ausreichend, um eine Aufzählung in der Domäne A durchzuführen.
In einem Szenario, in dem ext.local
die vertrauende Domäne und root.local
die vertraute Domäne ist, würde ein Benutzerkonto mit dem Namen EXT$
innerhalb von root.local
erstellt. Durch spezifische Tools ist es möglich, die Kerberos-Vertrauensschlüssel abzurufen, um die Anmeldeinformationen von EXT$
in root.local
offenzulegen. Der Befehl, um dies zu erreichen, lautet:
Nachfolgend könnte man den extrahierten RC4-Schlüssel verwenden, um sich als root.local\EXT$
innerhalb von root.local
mit einem anderen Befehlswerkzeug zu authentifizieren:
Diese Authentifizierungsschritt eröffnet die Möglichkeit, Dienste innerhalb von root.local
aufzulisten und sogar auszunutzen, z. B. durchführen eines Kerberoast-Angriffs zum Extrahieren von Servicekontozugangsdaten mit:
Sammeln des Klartext-Vertrauenspassworts
Im vorherigen Ablauf wurde anstelle des Klartextpassworts (das auch von mimikatz ausgelesen wurde) der Vertrauenshash verwendet.
Das Klartextpasswort kann erhalten werden, indem der [ CLEAR ]-Ausgabe von mimikatz von hexadezimal in Klartext umgewandelt und Nullbytes '\x00' entfernt werden:
Manchmal muss bei der Erstellung einer Vertrauensbeziehung ein Passwort vom Benutzer für das Vertrauen eingegeben werden. In dieser Demonstration ist der Schlüssel das ursprüngliche Vertrauenspasswort und daher menschenlesbar. Da der Schlüssel zyklisch ist (30 Tage), wird der Klartext nicht menschenlesbar sein, aber technisch immer noch verwendbar.
Das Klartextpasswort kann verwendet werden, um eine reguläre Authentifizierung als das Vertrauenskonto durchzuführen, eine Alternative zum Anfordern eines TGT unter Verwendung des Kerberos-Geheimschlüssels des Vertrauenskontos. Hier wird root.local von ext.local nach Mitgliedern der Domänenadministratoren abgefragt:
Referenzen
Last updated