Używanie Empire do przejęcia kontroli nad systemem

https://chacker.pl/

Upewnij się, że Empire nadal działa na komputerze Kali w laboratorium. W tym laboratorium wdrażamy naszego agenta, a następnie pracujemy nad eskalacją i całkowitym naruszeniem bezpieczeństwa systemu. Plik /tmp/launcher.bat będzie musiał zostać przeniesiony do naszego systemu Windows, więc jeśli serwer internetowy Python nadal działa, wystarczy, że skopiujemy go do naszego katalogu domowego. W nowym oknie SSH wpisujemy:

Następnie spróbujmy pobrać i uruchomić plik na docelowym systemie Windows w laboratorium. Aby to zrobić, możemy użyć polecenia iwr programu PowerShell:

Gdy wylistujesz katalog launcher.bat, możesz nie zobaczyć pliku, ponieważ program antywirusowy już go usunął. Nie panikuj. To normalne. Nasz plik został pomyślnie pobrany, ale nie działał prawidłowo, ponieważ został wykryty jako wirus, gdy AMSI sprawdził kod. Aby to obejść, możemy użyć obejścia AMSI i po prostu załadować sam skrypt. Zacznijmy od zmodyfikowania pliku bat na komputerze Kali, tak aby zawierał tylko ciąg Base64, usuwając wszystko do ciągu Base64:

Ten kod pobierze ciąg Base64 z pliku i zapisze go w pliku o nazwie dropper. Kod szuka wiersza programu PowerShell zawierającego enc, zamienia spacje na nowe wiersze, a następnie znajduje duży ciąg. To zadziała, nawet jeśli Empire nieznacznie zmieni konwencje wywołań. Teraz mamy plik o nazwie dropper w naszym katalogu domowym, który możemy wywołać z serwera WWW z naszego komputera z systemem Windows.

Najpierw ładujemy nasz skrypt obejścia AMSI i widzimy, że kończy się on pomyślnie. Ładujemy ciąg Base64 z serwera do zmiennej „$a”, a następnie konwertujemy go z Base64 za pomocą FromBase64String. Nadal musimy przekonwertować to wyjście na ciąg, więc Unicode.GetString konwertuje zmienną „$b” z naszym zdekodowanym ciągiem na ciąg, który iex może wykonać. To polecenie powinno się zawiesić i powinniśmy zobaczyć wyjście na naszym polu Kali w Empire.

Gdy nasz agent jest aktywny, następnym krokiem jest interakcja z tym agentem, jak pokazano poniżej. Należy pamiętać, że agenci są określani według nazwy, a Twoja może być inna. W naszym przypadku używamy CDE5236G.

Teraz, gdy wchodzimy w interakcję z naszym agentem, musimy ominąć środowisko User Account Control (UAC), aby uzyskać podniesioną powłokę do uruchomienia Mimikatz. Aby to zrobić, uruchamiamy polecenie bypassuac, które powinno utworzyć nową podniesioną powłokę, z którą będziemy mogli pracować:

Widzimy, że zadanie zostało uruchomione, ale nie otrzymaliśmy dodatkowej powłoki. Co więcej, jeśli spojrzymy na nasz komputer z systemem Windows, zostaliśmy wyrzuceni z programu PowerShell. Aktywności modułu bypassuac zostały uznane za złośliwe, więc program PowerShell został zamknięty, a teraz nasz agent również został zakończony. Na rysunku możemy zobaczyć, że agent przestał się meldować (czas jest czerwony na wyświetlaczu). W momencie pisania tej książki nie ma exploita obejścia UAC, który działałby dobrze w systemie Windows 2019 w Empire, więc będziemy musieli znaleźć inny sposób.

Przygotowanie Empire C2

https://chacker.pl/

Po skonfigurowaniu Empire musimy utworzyć program nasłuchujący, a następnie program nasłuchujący. Program nasłuchujący umożliwia nam uruchomienie naszego C2 w systemie docelowym. Program nasłuchujący odbiera komunikaty z zainfekowanych systemów. Konfigurujemy określone programy nasłuchujące dla określonych protokołów komunikacji. W naszym przykładzie użyjemy programu nasłuchującego opartego na protokole HTTP, aby po połączeniu się z nami program C2 wyglądał jak ruch sieciowy. Pierwszym krokiem jest skonfigurowanie programu nasłuchującego. Aby to zrobić, przechodzimy do menu programów nasłuchujących i wybieramy program nasłuchujący HTTP. Następnie włączamy podstawowe ustawienia i uruchamiamy program nasłuchujący, tak jak poniżej:

Teraz, gdy nasz listener jest uruchomiony, następnym krokiem jest utworzenie pliku bootstrap. Aby to zrobić, wracamy do menu głównego i wybieramy stager, jak pokazano tutaj:

Wybieramy moduł windows/launcher_bat dla naszego stagera. Spowoduje to, że otrzymamy polecenie PowerShell, które możemy skopiować i wkleić w systemie docelowym, aby uruchomić nasz C2. Określamy nasłuchiwacza, z którym chcemy się połączyć, i na koniec generujemy plik

Konfigurowanie Empire

https://chacker.pl/

Oryginalny PowerShell Empire został porzucony, ale BC Security przejął projekt, przeniósł go do Pythona 3 i nadal wprowadza aktualizacje. Jest to wersja, która jest teraz dołączona do Kali. Ponieważ będziemy chcieli użyć portów 80 i 443, musimy upewnić się, że inne usługi nie działają na tych portach, a następnie uruchomić PowerShell Empire za pomocą sudo.

Ten przykład pokazuje, że nginx działa. Aby to zatrzymać, wykonujemy następujące czynności (Twój system może mieć inny status w zależności od Twojej pozycji w laboratoriach):

Widzimy, że nginx jest teraz zatrzymany, więc możemy uruchomić Empire. Aby to zrobić, po prostu uruchamiamy binarny plik powershell-empire za pomocą sudo:

Po uruchomieniu Empire zobaczymy jego system menu i możemy wpisać help, aby zobaczyć opcje rozpoczęcia.

Używanie programu PowerShell Empire dla C2

https://chacker.pl/

Możliwość uruchamiania pojedynczych skryptów jest fajna, ale posiadanie kompleksowego frameworka do zdalnej interakcji z programem PowerShell lepiej sprawdza się w przypadku zaangażowań w świecie rzeczywistym. Tutaj wkracza Empire. Empire daje nam możliwości programu PowerSploit w frameworku z modułami. Stosuje również podejście beaconing, które można dostosować, dzięki czemu można lepiej ukryć interakcje z poleceniem i kontrolą (C2). W tej sekcji skonfigurujemy podstawowy C2, eskalujemy uprawnienia i dodamy trwałość w Empire.

Uruchamianie Mimikatz przez PowerShell

https://chacker.pl/

Jedną z niesamowitych funkcji PowerSploit jest możliwość wywołania Mimikatz przez PowerShell. Aby to zrobić, musimy wywołać skrypt Invoke-Mimikatz.ps1 z folderu Privesc. Spróbujmy. Zaloguj się do systemu docelowego Windows w laboratorium, a następnie użyj następujących poleceń:

Jedną z niesamowitych funkcji PowerSploit jest możliwość wywołania Mimikatz przez PowerShell. Aby to zrobić, musimy wywołać skrypt Invoke-Mimikatz.ps1 z folderu Privesc. Spróbujmy. Zaloguj się do systemu docelowego Windows w laboratorium, a następnie użyj następujących poleceń:

Obejście AMSI zadziałało! W tym przypadku widzimy, że skrypt został pomyślnie załadowany. Stąd możemy spróbować uruchomić Invoke-Mimikatz i sprawdzić, czy możemy uzyskać poświadczenia:

Tym razem posunęliśmy się trochę dalej, ale skrypt popełnił błąd. Jedną z wad PowerSploit jest to, że nie jest on aktywnie utrzymywany. Od jakiegoś czasu w repozytorium GitHub pojawia się wiele próśb o aktualizacje. Jedna z nich obejmuje skrypt Invoke-Mimikatz.ps1, który znajduje się w katalogu domowym Kali. Spróbujmy zamiast tego tej wersji:

Działa, ale jest kilka problemów. Pierwszą rzeczą, którą zauważamy, jest brak poświadczeń. Dzieje się tak, ponieważ ten użytkownik podlega Kontroli konta użytkownika (UAC), a użytkownik nie działa w podwyższonej powłoce. Drugą rzeczą, którą zauważamy, jest to, że PowerShell z jakiegoś powodu jest wyłączony. Kiedy zwracamy uwagę na alerty programu Windows Defender, widzimy, że program Defender wykrył złośliwą aktywność i zamknął nasz proces. Gdybyśmy byli w podwyższonym procesie, ten skrypt by zadziałał, ale ponieważ nie jesteśmy, musimy dowiedzieć się, jak uzyskać uprzywilejowaną powłokę. Ponieważ jesteśmy na konsoli, możemy po prostu poprosić o „Uruchom jako administrator”, ale gdybyśmy byli w sesji zdalnej, nie bylibyśmy w stanie tego zrobić.

Konfigurowanie PowerSploit

https://chacker.pl/

Wcześniej przyjrzeliśmy się różnym sposobom uruchamiania skryptów w PowerShell. W tej części rozdziału musimy skonfigurować PowerSploit, aby mieć do niego łatwy dostęp. Dzięki naszej konfiguracji w chmurze mamy już sklonowanego PowerSploit do katalogu lokalnego, a ponieważ znajduje się on w naszym katalogu domowym, jest również mapowany na naszym udziale SMB i serwerze internetowym uruchomionym w poprzednim ćwiczeniu.

UWAGA: Niektóre samouczki online umożliwią Ci dostęp do plików w PowerSploit i innych kodów exploitów bezpośrednio z GitHub przy użyciu surowej witryny .githubusercontent.com. Jest to niezwykle niebezpieczne, ponieważ nie zawsze znasz stan tego kodu, a jeśli go nie przetestowałeś, możesz uruchomić coś destrukcyjnego na swoim celu. Zawsze klonuj repozytorium i testuj skrypty, które zamierzasz uruchomić na maszynie wirtualnej, zanim uruchomisz je w systemie docelowym, aby Ty, Twój klient i Twoi prawnicy nie byli zaskoczeni. Aby ułatwić dostęp do adresów URI, zmieńmy nazwę katalogu na krótszą. Miejsce nie jest tutaj problemem; jednak gdy próbujemy przemycić zakodowane dane, kodowanie dodaje więcej znaków, więc krótsza nazwa jest często lepsza. Aby zmienić nazwę katalogu, po prostu wpisz następujące polecenie:

Gdy „cd” przejdziemy do katalogu ps, zobaczymy kilka plików i strukturę katalogów. Przyjrzyjmy się bliżej temu, co możemy znaleźć w każdym katalogu:

Podkatalog AntivirusBypass zawiera skrypty, które pomagają nam ustalić, gdzie w pliku binarnym program antywirusowy (AV) może identyfikować plik jako złośliwe oprogramowanie. Skrypty w tym miejscu pomagają podzielić plik binarny na części, a następnie te części są uruchamiane przez AV. Następnie, gdy zawęzisz zakres tak bardzo, jak to możliwe, możesz zidentyfikować bajty w pliku binarnym, które należy zmienić, aby ominąć podpis AV. Podkatalog CodeExecution zawiera różne narzędzia do wprowadzania kodu powłoki do pamięci. Niektóre z tych technik obejmują wstrzykiwanie DLL, wstrzykiwanie kodu powłoki do procesu, wstrzykiwanie refleksyjne i wstrzykiwanie zdalnego hosta za pomocą WMI. Przyjrzymy się niektórym z tych technik później w tym rozdziale jako sposobowi wstrzykiwania kodu powłoki Metasploit do systemu bez użycia plików. Gdy chcesz uzyskać informacje z systemu, zajrzyj do folderu Exfiltration. Ten folder zawiera narzędzia, które pomogą Ci kopiować zablokowane pliki, pobierać dane z Mimikatz i nie tylko. Niektóre z innych atrakcji obejmują keyloggery, narzędzia do zrzutów ekranu, programy do zrzutu pamięci i narzędzia pomocne w Volume Shadow Service (VSS). Te narzędzia nie pomagają w usuwaniu danych z systemu, ale świetnie nadają się do generowania danych, które warto wyekstrahować. Jeśli chcesz postępować zgodnie z zasadą spalonej ziemi, folder Mayhem jest dla Ciebie. Skrypty w tym katalogu nadpiszą Master Boot Record (MBR) systemu wybranym przez Ciebie komunikatem. W wielu przypadkach wymaga to przywrócenia systemu z kopii zapasowej, więc jeśli Twój cel zawiera coś, co Ci się podoba, trzymaj się z daleka od tego katalogu. Katalog Persistence zawiera narzędzia, które pomagają utrzymać dostęp do systemu. Dostępnych jest wiele mechanizmów trwałości, w tym rejestr, WMI i zaplanowane zadania. Te narzędzia pomagają tworzyć trwałość zarówno na poziomie podwyższonym, jak i na poziomie użytkownika; w ten sposób, niezależnie od potrzebnego poziomu dostępu, możesz łatwo utrzymać trwałość w systemach docelowych. Katalog PrivEsc zawiera narzędzia, które pomogą Ci uzyskać podwyższony dostęp. Są to narzędzia, które pomagają zidentyfikować słabe uprawnienia, które mogą zostać wykorzystane, jak również narzędzia, które faktycznie wykonują część pracy za Ciebie.  Katalog Recon zawiera narzędzia, które mogą pomóc Ci lepiej zrozumieć środowisko, w którym pracujesz. Narzędzia te są przydatne do zbierania podstawowych informacji, skanowania portów i uzyskiwania informacji o domenach, serwerach i stacjach roboczych. Mogą pomóc Ci zidentyfikować to, co chcesz osiągnąć, a także pomóc Ci w tworzeniu profili dla tego, co istnieje w środowisku

Eksploatacja i posteksploatacja z PowerSploit

https://chacker.pl/

PowerSploit to zbiór narzędzi zaprojektowanych, aby pomóc testerom penetracyjnym w nawiązaniu przyczółka i eskalacji w środowisku. Narzędzia te zostały uwzględnione w innych ramach, takich jak PowerShell Empire i Social Engineering Toolkit (SET). Te narzędzia pomagają nam ustanawiać powłoki, wstrzykiwać kod do procesów, wykrywać i łagodzić AV i nie tylko. Po nawiązaniu dostępu do komputera te narzędzia mogą pomóc nam w eskalacji i zrzucaniu krytycznych informacji systemowych. Zrozumienie, w jaki sposób te narzędzia współpracują z resztą naszego zestawu narzędzi, pomoże nam uzyskać i utrzymać dostęp do komputerów, a także propagować w całej domenie. W tej sekcji przyjrzymy się kilku przydatnym narzędziom w pakiecie PowerSploit i wykorzystamy je do utworzenia przyczółka bez konieczności instalowania dodatkowych narzędzi w systemie.PowerSploit to zbiór narzędzi zaprojektowanych, aby pomóc testerom penetracyjnym w nawiązaniu przyczółka i eskalacji w środowisku. Narzędzia te zostały uwzględnione w innych ramach, takich jak PowerShell Empire i Social Engineering Toolkit (SET). Te narzędzia pomagają nam ustanawiać powłoki, wstrzykiwać kod do procesów, wykrywać i łagodzić AV i nie tylko. Po nawiązaniu dostępu do komputera te narzędzia mogą pomóc nam w eskalacji i zrzucaniu krytycznych informacji systemowych. Zrozumienie, w jaki sposób te narzędzia współpracują z resztą naszego zestawu narzędzi, pomoże nam uzyskać i utrzymać dostęp do komputerów, a także propagować w całej domenie. W tej sekcji przyjrzymy się kilku przydatnym narzędziom w pakiecie PowerSploit i wykorzystamy je do utworzenia przyczółka bez konieczności instalowania dodatkowych narzędzi w systemie.

Bootstrapping przez Internet

https://chacker.pl/

W przypadku złożonych skryptów kodowanie ich nie zawsze jest najlepszym rozwiązaniem. Jedną z innych opcji jest umieszczenie ich na stronie internetowej, załadowanie skryptów, a następnie bootstrapowanie ich w naszym kodzie. Dwie funkcje w programie PowerShell pomagają nam to zrobić:

Invoke-Expression i Invoke-WebRequest.

Funkcja Invoke-WebRequest wyjdzie i pobierze stronę internetową, a następnie zwróci jej zawartość. Pozwala nam to umieścić stronę w Internecie z naszym kodem, a następnie pobrać ją z poziomu programu PowerShell. Ta funkcja domyślnie używa silnika IE, którego nasz komputer z systemem Windows 2019 mógł nie zainicjować, więc będziemy musieli użyć obejścia, aby upewnić się, że może pobrać nasze strony internetowe. Możemy użyć opcji -UseBasicParsing, aby powiedzieć funkcji, aby nie próbowała analizować wyników, ale zamiast tego po prostu je nam zwróciła. Funkcja Invoke-Expression ocenia przekazany jej kod. Możemy załadować kod z pliku, a następnie przekazać go przez stdin lub inną opcję. Jedną z najczęstszych metod, z których korzystają atakujący, jest jednak przekazanie Invoke-Expression wyniku z żądania internetowego, aby mogli uruchomić większe programy bez obaw o blokowanie skryptów. Na początek utwórzmy plik, który chcemy obsługiwać, a następnie możemy uruchomić podstawowy serwer Pythona w tle. Na polu Kali w laboratorium wpisz następujące polecenie:

Nasz plik nazywa się t.ps1, ponieważ chcemy wpisać jak najmniej. Dzięki naszemu serwerowi WWW działającemu na Kali (w tym przykładzie 10.0.0.40) i naszemu kodowi w t.ps1 możemy wykonać kod za pomocą wiersza poleceń programu PowerShell z naszego docelowego systemu Windows bez konieczności martwienia się o użycie opcji encodedcommand. Użyj powłoki poleceń, używając kontekstu użytkownika „target”:

Tutaj połączyliśmy nasze dwa polecenia, aby pobrać plik z naszego pudełka Kali i wykonać go. Daje nam to taki sam wynik, jak przy uruchamianiu lokalnym, i nie otrzymaliśmy żadnych komunikatów o błędach, które widzieliśmy wcześniej, gdy próbowaliśmy wykonać skrypty. Możemy zrobić to samo ze ścieżkami Universal Naming Convention (UNC). W tej części laboratorium użyjemy smbserver Impacket, aby udostępnić nasz katalog. Chcemy nazwać nasz udział ghh i chcemy, aby był mapowany na nasz katalog lokalny. Uruchomimy go również w tle. Będziemy mogli zobaczyć wynik z serwera na naszym ekranie, ale nadal będziemy mogli wpisywać polecenia.

Na koniec możemy przetestować naszą usługę Samba. Gdy smbclient poprosi o hasło, po prostu naciśnij ENTER.

Po uruchomieniu usługi tworzymy listę udziałów za pomocą smbclient, aby zweryfikować, czy nasz udział został pomyślnie dodany. Po skonfigurowaniu udziałów możemy teraz odwołać się do tego samego skryptu za pomocą ścieżki UNC. Zamiast używać wiersza poleceń, uruchommy plik wykonywalny programu PowerShell bez żadnych opcji wiersza poleceń i wypróbujmy to:

Tutaj zastosowaliśmy to samo podstawowe podejście ze ścieżką UNC zamiast adresu URL. Daje nam to kilka różnych sposobów wykonywania kodu na komputerach bez konieczności zmiany zasad programu PowerShell.

Zakodowane polecenia

https://chacker.pl/

Kiedy mamy bardziej złożone zadanie, miło jest nie martwić się o formatowanie. PowerShell ma przydatny tryb, który pozwala nam przekazać zakodowany ciąg Base64 jako skrypt do uruchomienia — pod warunkiem, że skrypt nie jest zbyt długi. Całkowita długość polecenia wiersza poleceń systemu Windows wynosi około 8000 znaków, więc to jest twój limit. Musimy wprowadzić kilka zmian, aby utworzyć zakodowane polecenie. Przede wszystkim opcja encodedcommand programu PowerShell przyjmuje zakodowany ciąg Unicode Base64, więc najpierw musimy przekonwertować nasz tekst na Unicode, a następnie zakodować go jako Base64. Aby to zrobić, potrzebujemy łatwego sposobu na konwersję do kodowania Base64. Chociaż moglibyśmy użyć narzędzi już dostępnych w Kali, aby to zrobić, użyjemy jednego z moich ulubionych zestawów narzędzi, Ruby BlackBag autorstwa Erica Montiego. Ten klejnot Ruby zawiera wiele narzędzi do kodowania i dekodowania, które pomagają zarówno w analizie złośliwego oprogramowania, jak i hakowaniu. SSH do instancji Kali w laboratorium. Najpierw musimy ją zainstalować, zanim będziemy mogli jej używać:

Po zainstalowaniu tego zestawu narzędzi nie tylko dodaje on funkcjonalność Ruby, ale także tworzy kilka skryptów pomocniczych — jeden z nich nazywa się b64, narzędzie do konwersji Base64. Następnie weźmiemy to samo polecenie, którego użyliśmy w poprzednim laboratorium, i przekonwertujemy je na ciąg Base64 zgodny z PowerShell:

Tutaj używamy echo z opcją -n, aby wydrukować nasze polecenie PowerShell bez włączania nowej linii. Następnie przekazujemy to do iconv, konwertera zestawów znaków, który przekonwertuje nasz tekst ASCII na UTF-16LE, format Windows Unicode. Na koniec przekazujemy to wszystko do b64, jak pokazano poniżej. Ciąg, który on wyprowadza, to ciąg, którego będziemy używać z PowerShell na naszym docelowym systemie Windows w laboratorium.

Powinien pojawić się następujący wynik:

Tutaj widać, że gdy przekazujemy nasz ciąg z opcją -enc, otrzymujemy oczekiwany wynik. Teraz możemy budować bardziej złożone skrypty i przekazywać cały skrypt w wierszu poleceń, dzięki czemu nie musimy się martwić o zapobieganie wykonywaniu skryptów. Oprócz użycia sztuczki b64, możemy to również zrobić bezpośrednio z PowerShell w Kali. Ta instancja ma zainstalowany Microsoft PowerShell i jest wykonywalna za pomocą polecenia pwsh. Możemy używać większości poleceń PowerShell tak samo, jak moglibyśmy to robić w systemie Windows.

Aby wyjść z powłoki PowerShell, wpisz polecenie exit, aby powrócić do zwykłych monitów powłoki.

Przekazywanie poleceń w wierszu poleceń

https://chacker.pl/

Wcześniej wykonaliśmy szereg poleceń programu PowerShell z wiersza poleceń.Tu przyjrzymy się, jak wykonywać bardziej złożone polecenia. W poprzednich przykładach widziałeś, że opcja -command może być używana do przekazywania poleceń w wierszu poleceń; jednak wiele opcji programu PowerShell można skrócić. W tym laboratorium zaloguj się ponownie do komputera docelowego w laboratorium, używając protokołu RDP jako użytkownika docelowego. Uruchom powłokę poleceń, używając uprawnień użytkownika „docelowego”. W tym przypadku możemy po prostu użyć opcji -com, jak pokazano tutaj, i zaoszczędzić sobie pisania:

Tutaj mogliśmy wydać proste zapytanie Windows Management Instrumentation (WMI) za pomocą programu PowerShell i bez żadnych dodatkowych cudzysłowów wokół zapytania. W przypadku podstawowych zapytań będzie to działać dobrze; jednak w przypadku bardziej złożonych zapytań możemy napotkać problem. Zobaczmy, co się stanie, gdy spróbujemy uzyskać dodatkowe informacje o nazwie hosta:

Tutaj widać, że nie mogliśmy użyć znaku potoku do przekazywania danych z jednej metody do drugiej, ponieważ jest on interpretowany przez system operacyjny. Najłatwiejszym sposobem obejścia tego jest użycie cudzysłowów, tak jak tutaj:

Zwróć uwagę, że nazwa hosta może być inna. Tym razem znak potoku nie został zinterpretowany przez system operacyjny, więc mogliśmy uzyskać tylko informacje o nazwie hosta z wyjścia zapytania WMI. W przypadku prostych poleceń działa to dobrze, a jeśli wykonujemy tylko kilka z tych poleceń, dość łatwo jest dodać je do skryptu wsadowego i uruchomić je stamtąd.