Harvesting tickets from Linux
Credential Storage in Linux
Linux-Systeme speichern Anmeldeinformationen in drei Arten von Caches, nämlich Dateien (im Verzeichnis /tmp
), Kernel-Keyrings (ein spezieller Abschnitt im Linux-Kernel) und Prozessspeicher (für die Nutzung durch einen einzelnen Prozess). Die Variable default_ccache_name in /etc/krb5.conf
zeigt den verwendeten Speichertyp an, standardmäßig FILE:/tmp/krb5cc_%{uid}
, wenn nicht angegeben.
Extracting Credentials
Das Papier von 2017, Kerberos Credential Thievery (GNU/Linux), beschreibt Methoden zum Extrahieren von Anmeldeinformationen aus Keyrings und Prozessen und betont den Keyring-Mechanismus des Linux-Kernels zur Verwaltung und Speicherung von Schlüsseln.
Keyring Extraction Overview
Der keyctl-Systemaufruf, der in der Kernel-Version 2.6.10 eingeführt wurde, ermöglicht es Anwendungen im Benutzerspeicher, mit Kernel-Keyrings zu interagieren. Anmeldeinformationen in Keyrings werden als Komponenten (Standardprinzipal und Anmeldeinformationen) gespeichert, die sich von Datei-ccaches unterscheiden, die auch einen Header enthalten. Das hercules.sh-Skript aus dem Papier demonstriert das Extrahieren und Rekonstruieren dieser Komponenten in eine verwendbare Datei-ccache für den Diebstahl von Anmeldeinformationen.
Ticket Extraction Tool: Tickey
Auf den Prinzipien des hercules.sh-Skripts basierend, ist das tickey-Tool speziell zum Extrahieren von Tickets aus Keyrings konzipiert und wird über /tmp/tickey -i
ausgeführt.
References
Last updated