O objetivo é de conscientizar tanto usuários como organizações, sobre a importância de implementar os melhores controles e as levar as boas práticas de segurança para seus usuários.
Introdução
Antes de iniciarmos os nossos testes, vamos definir como será o nosso laboratório, afinal não vamos usar ambientes reais, mas sim laboratórios controlados por mim ao qual vou simular um ataque real.
E nesse laboratório vai conter:
Kali Linux (Máquina que vou utilizar para os ataques)
Website com servidor Linux (Metasploitable, Ubuntu)
Windows 7 vulnerável
Então é com essas máquinas que vamos realizar os nossos testes
Contrato e Escopo
A equipe comercial enviou o contrato aonde o cenário é Black Box, aonde o cliente apenas fornece o nome da organização, com isso você vai precisar arrumar uma forma de ganhar acesso ao ambiente. E claro ele não restringiu ninguém fora do escopo, então ele se torna um potencial alvo também.
Planejamento
Após definir o Escopo dos testes, agora vamos preparar a nossa metodologia, ao qual se resume em
Coleta de Informação
Varredura
Exploração
Pós-exploração
Essas 4 etapas, claro adicionando a última relacionada ao report que será feito para o cliente, caso você queira entender um pouco mais sobre relatórios de PenTest eu recomendo esse artigo que eu mesmo fiz:
Iniciando o PenTest
Fase de Coleta de Informação
Definido todos as questões comerciais, agora vamos realizar os testes, mas como o cliente não passou nenhum IP e nem uma aplicação, vamos ter que ir atrás de informações da empresa e do nome dele.
Por ora sabemos apenas os nome da empresa e dele, certo?
Vamos ver se ele tem LinkedIn?
Bingo! Achamos o LinkedIn dele, parece que contém algumas informações a mais sobre ele como, aonde ele trabalhou, suas funções e também achamos o nome da empresa ao qual ele é CEO, porém o seu LinkedIn não é bem atualizado.
Mas pelo menos já sabemos algumas coisas sobre ele, porém ainda preciso vasculhar esse perfil e procurar talvez o website ou alguma outra informação.
Cliquei no icone da empresa e fui redirecionado para sua página no LinkedIn, e analisando podemos ver que a empresa possui 94 funcionários, vou clicar e vasculhar cada perfil até achar o site da empresa.
Após uma varredura eu encontrei uma funcionária que mora no Reino Unido, ao qual trabalha na área de Marketing da empresa, então já temos o website da empresa, agora vamos em busca de levantar informações e fazer a varredura.
Nesse momento com a URL na mão vamos seguir as 4 etapas em busca de ganhar uma shell reversa.
Após conseguir a URL do website, eu vou atrás do endereço de ip do servidor e torcer para ser uma host próprio.
Então para isso vou utilizar o dig para verificar o nameserver.
Então notamos que o IP 10.0.0.10 é relacionado ao servidor web (nosso alvo) e o 10.0.0.9 é relacionado ao servidor DNS. Com isso, vamos filtrar o endereço 10.0.0.10 e agora vamos partir para o nosso Kali Linux.
Poderiamos utilizar um Maltego para realizar um OSINT profundo no site e verificar outros IP administradores, subdominios ligados, emails registrados e etc…
Além disso, você poderia utilizar ferramentas como Recon-ng, theHaverster ou Dnsrecon.
Scanning
Agora vamos para a parte de varredura e verificar quais serviços e porta esse servidor utiliza, então eu vou sair do meu Ubuntu Server para o Kali Linux.
E para isso vamos utilizar o NMAP uma ferramenta padrão para uma varredura.
Para niciar vou fazer uma varredura básica, sem pingar a máquina
Ele me retornou muitas portas e serviços aberto, isso é interessante, podemos ir atrás de um Exploit para garantir uma shell reversa no servidor.
No caso vou explorar algo pelo FTP, mas vamos verificar a versão do serviço.
Interessante, uma versão 2.3.4 ela é bem conhecida por ser vulnerável, vamos procurar algo no Exploit-db
Achamos algo sobre essa vulnerabilidade, então vamos ao metasploit para verificar se termos o exploit dessa falha
E em uma rápida pesquisa deu para encontrar uma exploit para essa versão do vsftpd, então partindo disso eu vou utilizar esse exploit e configurar os devidos parâmetros
Fase de Exploração
Selecionamos o exploit, depois passamos o RHOSTS que seria o nosso alvo, nesse caso o servidor web e agora vamos precisar definir o payload para nos retornar uma shell reversa, caso a exploração seja bem sucedida.
Digitando:
Temos esse cmd/unix/interact, então vamos passar os parâmetros para sua utilização
Dando um options é de se notar que não tem necessidade de configurar um LHOST ou algo do tipo, então basta digitarmos “exploit” para iniciar a nossa exploração.
Bingo! Conseguimos uma shell reversa no servidor, agora só precisamos digitar: sessions -i “numero da sessão” para ter acesso a shell.
E aqui já digitei o meu primeiro comando: ls
Fase de Pós Exploração
Como ganhamos acesso root, não precisamos realizar uma escalação de privilégios, porém podemos utilizar o python para fazer uma shell interativa.
Com isso, ele nos retorna uma shell mais apresentável e mais fácil de trabalhar.
Agora vamos tentar elevar de uma simples shell para um meterpreter?
Para isso, vou utilizar um módulo que se encontra no próprio metasploit, mas antes precisamos deixar nossa shell em segundo plano e para isso digite:
Depois de dar um “Yes” pesquise por “Shell_to_meterpreter”
Agora basta apenas passar os parâmetros desse módulo que seria um módulo de pós exploração.
E agora vamos ver suas opções
Perceba que vamos precisar passar o número da sessão que está rodando aquela simples shell, então é só digitar: “sessions -l” e pegar o “id”
Possuindo essa informação, vamos digitar: “set SESSION 1″
Pronto! Agora só digitar: “exploit” e torcer para ocorrer a migração
Ele nos retornou um erro na hora de executar o módulo, mas podemos verificar se ele abriu a sessão de qualquer maneira.
Parece que ele abriu uma segunda sessão, vamos tentar entrar nela?
Bacana! Conseguimos obter uma shell meterpreter, agora podemos realizar uma Pós-exploração bem melhorada.
Digitando “help” ele nos retorna diversos comandos.
Mas agora, vamos realizar uma outra etapa da exploração, após realizar as tentativas de PIVOTING e não conseguir sucesso, você pode recorrer para outros métodos.
Porém eu ressalto que um Movimento lateral ou Pivoting é uma boa opção, pois é 100% mais efetivo como os métodos que vamos realizar agora.
Agora basicamente vamos tentar ganhar uma shell reversa por intermédio das informações que temos da pessoa pelo LinkedIn.
E esse método vai nos retornar para a coleta de informação, obviamente você já pode ter realizado essa etapa antes mesmo e ter garantido acesso as informações como o e-mail de algum funcionário.
Nessa etapa vamos tentar comprometer alguém de dentro da empresa por meio de um simples e-mail com um anexo malicioso que no caso seria um PDF.
Então nesse caso eu vou ir até a página do LinkedIn da empresa e procurar algum funcionário que deixou seu email de maneira publica ou algum tipo de contato. Alguns deixam email para contato e muitas vezes o email comercial da empresa fica exposto.
Você pode também utilizar ferramentas como o maltego para realizar um OSINT.
No caso eu acessei um perfil de um funcionário e clicando na aba de “Informações de Contato” eu encontrei as seguintes informação
Perceba que temos agora o Email de Johndoe, então para isso eu vou me passar por uma empresa como a Microsoft, fingindo que vou enviar um arquivo em pdf com uma boa proposta e torcer para ele abrir, mas já vamos partir do principio que possuimos a versão do adobe reader que a empresa utiliza por métodos como e-mail tracking e coleta de informações.
Uma boa ferramenta: https://www.readnotify.com/
Agora vamos gerar um pdf malicioso, para isso eu vou usar uns modelos existentes no Kali, mas você pode criar um pdf novo ou utilizar algum que você achar interessante.
Se eu der o comando: “locate .pdf” ele vai me retornar diversos pdfs de algumas ferramentas ou em branco, você pode utilizar qualquer um desses.
Vamos agora para a exploração?
O adobe reader é um software bem vulnerável, se digitarmos dentro do “msfconsole” o comando “search pdf” vamos ter diversos resultados
Especificamente 172 resultados, mas vamos definir um exploit para podermos comprometer o alvo, pois na coleta de informação foi detectado uma versão do Adobe Reader bem antiga.
E já sei até um bom exploit para esse tipo de caso
Vamos selecionar o primeiro exploit e definir os devidos parâmetros.
Digitando “options” notamos que ele já tem definido o nome do pdf e o template que ele vai utilizar para que o evil.pdf se passe por ele.
Eu poderia definir uma Mensagem para que aparecesse na hora que a vítima executasse.
No meu caso vou manter os parâmetros como está, apenas definirei o payload que será um Meterpreter
Agora só nos resta definir nosso “LHOST” e com isso estamos livre para gerar nosso payload.
Como lembrado o LHOST é nosso endereço IP, nosso endereço local, ou seja, o IP da minha máquina.
Agora vamos digitar “exploit” e esperar a mágica acontecer.
Pronto! Geramos nosso pdf malicioso e agora é só preparar a engenharia social, perceba que ele parou no diretório /root/.msf4/local/evil.pdf, porém poderiamos mover ele para qualquer outro local, mas vou deixar aonde ele está mesmo e enviar um e-mail falso se passando por uma empresa como a famosa Microsoft.
Nessa etapa vou realizar um Email Spoofing utilizando a ferramenta Emkei, para acessar essa ferramenta basta entrar nesse site
Agora vamos criar um e-mail falso
Então definimos o nome do remetente e seu e-mail, definimos também o destinatário e o titulo ou sujeito da nossa mensagem. E por fim eu coloquei o arquivo malicioso e uma mensagem para a vítima.
Agora é só enviar!
Mas antes no metasploit vamos iniciar uma shell reversa, então para isso vou utilizar um exploit genérico como o multi/handler.
Agora vamos ter que definir o mesmo payload ao qual foi utilizado para gerar o nosso pdf malicioso, e além disso temos que inserir os mesmos parâmetros que passamos também.
Vamos definir o nosso LHOST e ai é só executarmos e esperar a vítima abrir o pdf.
Abrirmos o Handler, aonde ele está esperando a vitima abrir o pdf e garantir a shell reversa
Aqui é o e-mail com o anexo malicioso, no caso eu baixei e agora vou executar.
Esse é o anexo, agora só precisamos clicar nele.
Ao abrir ele vai aparecer essa mensagem, vale ressaltar que poderiamos modificar essa mensagem para algum tipo de erro existente, mas como é um laboratório podemos clicar em Open sem problema.
Bingo! Temos nossa shell reversa e agora é só garantirmos a persistência e efetuar a escalação de privilégios.
Contras desse método
- Obviamente utilizamos um Laboratório, então não nos preocupamos com bypass, mas vale ressaltar que um ambiente corporativo vai ter filtros anti-spam e antivírus, por isso é bom conhecer de métodos de obfuscação e bypass.
- Muitos e-mail tem mecanismos de analise, então é bom conhecer de bypass também.
- Utilizar o emkei não é garantido que seu e-mail chegue, então é bom utilizar as opções avançadas como a opção de “confirmação de leitura e envio”
- Nem sempre vai ter uma versão do adobe vulnerável, então busque outros métodos iguais envolvendo o pacote office e macro, além disso você pode partir para a criação de Trojans para comprometer seu alvo.
Conclusão
Esse é um dos métodos para garantir uma shell reversa por meio do LinkedIn, vale ressaltar que cada informação é valiosa e isso ajuda muito em um PenTest, obviamente simulamos uma situação um caso prático, porém é mais comum do que parece, afinal ninguém se preocupa com a versão do sistema ou software que usa e isso é um grande risco. Além disso as redes sociais são as maiores amigas de um PenTester, afinal com informações básicas de email e o website, conseguimos 2 shell reversa e até mesmo podemos realizar um Movimento lateral em busca de comprometer mais máquinas em uma rede.
Então tome cuidado com suas informações e sempre respeite as politicas de segurança e implemente mecanismos de proteção avançada.
Espero que vocês tenham gostado desse artigo, foi básico, mas vale ressaltar que a partir disso você tem inúmeras possibilidades.
Veja outros artigos meus: https://www.linkedin.com/in/joas-antonio-dos-santos/
Views: 280