Stack Pivoting - EBP2Ret - EBP chaining
Last updated
Last updated
Learn & practice AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE) Learn & practice GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Ta technika wykorzystuje zdolność do manipulacji wskaźnikiem bazowym (EBP) w celu połączenia wykonania wielu funkcji poprzez staranne użycie rejestru EBP oraz sekwencji instrukcji leave; ret
.
Przypominając, leave
zasadniczo oznacza:
And as the EBP is in the stack before the EIP it's possible to control it controlling the stack.
Ta technika jest szczególnie przydatna, gdy możesz zmienić rejestr EBP, ale nie masz bezpośredniego sposobu na zmianę rejestru EIP. Wykorzystuje zachowanie funkcji po zakończeniu ich wykonywania.
Jeśli podczas wykonywania fvuln
uda ci się wstrzyknąć fałszywy EBP na stos, który wskazuje na obszar w pamięci, gdzie znajduje się adres twojego shellcode (plus 4 bajty na operację pop
), możesz pośrednio kontrolować EIP. Gdy fvuln
zwraca, ESP jest ustawione na to skonstruowane miejsce, a następna operacja pop
zmniejsza ESP o 4, efektywnie wskazując na adres przechowywany przez atakującego.
Zauważ, że musisz znać 2 adresy: Ten, na który ESP ma iść, gdzie będziesz musiał zapisać adres, na który wskazuje ESP.
Najpierw musisz znać adres, w którym możesz zapisać dowolne dane/adresy. ESP będzie wskazywać tutaj i wykona pierwsze ret
.
Następnie musisz znać adres używany przez ret
, który wykona dowolny kod. Możesz użyć:
Ważny ONE_GADGET adres.
Adres system()
po którym następują 4 bajty śmieci i adres "/bin/sh"
(x86 bits).
Adres gadżetu jump esp;
(ret2esp) po którym następuje shellcode do wykonania.
Jakiegoś łańcucha ROP
Pamiętaj, że przed którymkolwiek z tych adresów w kontrolowanej części pamięci muszą być 4
bajty z powodu pop
w instrukcji leave
. Możliwe byłoby wykorzystanie tych 4B do ustawienia drugiego fałszywego EBP i kontynuowania kontroli wykonania.
Istnieje specyficzna odmiana tej techniki znana jako "Off-By-One Exploit". Jest używana, gdy możesz zmodyfikować tylko najmniej znaczący bajt EBP. W takim przypadku lokalizacja pamięci przechowująca adres, do którego należy skoczyć z ret
, musi dzielić pierwsze trzy bajty z EBP, co pozwala na podobną manipulację w bardziej ograniczonych warunkach.
Zwykle modyfikowany jest bajt 0x00, aby skoczyć jak najdalej.
Ponadto, powszechnie używa się RET sled w stosie i umieszcza prawdziwy łańcuch ROP na końcu, aby zwiększyć prawdopodobieństwo, że nowy ESP wskazuje wewnątrz RET SLED, a końcowy łańcuch ROP jest wykonywany.
Dlatego umieszczając kontrolowany adres w wpisie EBP
stosu i adres do leave; ret
w EIP
, możliwe jest przeniesienie ESP
do kontrolowanego adresu EBP
ze stosu.
Teraz ESP
jest kontrolowane, wskazując na pożądany adres, a następna instrukcja do wykonania to RET
. Aby to wykorzystać, można umieścić w kontrolowanym miejscu ESP to:
&(next fake EBP)
-> Załaduj nowy EBP z powodu pop ebp
z instrukcji leave
system()
-> Wywołane przez ret
&(leave;ret)
-> Wywołane po zakończeniu systemu, przeniesie ESP do fałszywego EBP i zacznie ponownie
&("/bin/sh")
-> Parametr dla system
W zasadzie w ten sposób można łączyć kilka fałszywych EBP, aby kontrolować przepływ programu.
To jest jak ret2lib, ale bardziej skomplikowane bez oczywistych korzyści, ale może być interesujące w niektórych skrajnych przypadkach.
Ponadto, tutaj masz przykład wyzwania, które wykorzystuje tę technikę z wyciekiem stosu, aby wywołać zwycięską funkcję. To jest końcowy ładunek z tej strony:
Jak wyjaśniono w tym poście, jeśli binarka jest kompilowana z pewnymi optymalizacjami, EBP nigdy nie kontroluje ESP, w związku z tym, każdy exploit działający poprzez kontrolowanie EBP zasadniczo nie powiedzie się, ponieważ nie ma rzeczywistego efektu. Dzieje się tak, ponieważ prolog i epilog zmieniają się, jeśli binarka jest zoptymalizowana.
Nieoptymalizowane:
Optymalizowane:
pop rsp
gadgetNa tej stronie znajdziesz przykład użycia tej techniki. W tym wyzwaniu konieczne było wywołanie funkcji z 2 konkretnymi argumentami, a tam był pop rsp
gadget i był leak ze stosu:
Sprawdź technikę ret2esp tutaj:
Ret2esp / Ret2reg64 bity, exploatacja off by one z łańcuchem rop zaczynającym się od ret sled
64 bity, brak relro, canary, nx i pie. Program umożliwia leak dla stosu lub pie i WWW dla qword. Najpierw uzyskaj leak stosu i użyj WWW, aby wrócić i uzyskać leak pie. Następnie użyj WWW, aby stworzyć wieczną pętlę, nadużywając wpisów .fini_array
+ wywołując __libc_csu_fini
(więcej informacji tutaj). Nadużywając tego "wiecznego" zapisu, zapisuje się łańcuch ROP w .bss i kończy wywołując go, pivotując z RBP.
W ARM64, prologi i epilogi funkcji nie przechowują ani nie odzyskują rejestru SP w stosie. Co więcej, instrukcja RET
nie zwraca do adresu wskazywanego przez SP, ale do adresu wewnątrz x30
.
Dlatego, domyślnie, nadużywając epilogu, nie będziesz w stanie kontrolować rejestru SP przez nadpisanie danych w stosie. A nawet jeśli uda ci się kontrolować SP, nadal potrzebujesz sposobu na kontrolowanie rejestru x30
.
prolog
epilog
Sposobem na wykonanie czegoś podobnego do stack pivoting w ARM64 byłoby być w stanie kontrolować SP
(poprzez kontrolowanie jakiegoś rejestru, którego wartość jest przekazywana do SP
lub ponieważ z jakiegoś powodu SP
bierze swój adres ze stosu i mamy overflow) i następnie nadużyć epilogu, aby załadować rejestr x30
z kontrolowanego SP
i RET
do niego.
Również na następnej stronie możesz zobaczyć odpowiednik Ret2esp w ARM64:
Ret2esp / Ret2regUcz się i ćwicz Hacking AWS:HackTricks Training AWS Red Team Expert (ARTE) Ucz się i ćwicz Hacking GCP: HackTricks Training GCP Red Team Expert (GRTE)