euid, ruid, suid
Reading time: 8 minutes
tip
Leer en oefen AWS Hacking:
HackTricks Training AWS Red Team Expert (ARTE)
Leer en oefen GCP Hacking:
HackTricks Training GCP Red Team Expert (GRTE)
Leer en oefen Azure Hacking:
HackTricks Training Azure Red Team Expert (AzRTE)
Ondersteun HackTricks
- Kyk na die subskripsie planne!
- Sluit aan by die 💬 Discord groep of die telegram groep of volg ons op Twitter 🐦 @hacktricks_live.
- Deel hacking truuks deur PRs in te dien na die HackTricks en HackTricks Cloud github repos.
Gebruiker Identifikasie Veranderlikes
ruid: Die werklike gebruiker ID dui die gebruiker aan wat die proses begin het.euid: Bekend as die effektiewe gebruiker ID, dit verteenwoordig die gebruiker identiteit wat deur die stelsel gebruik word om proses regte te bepaal. Gewoonlik spieëleuidruid, behalwe in gevalle soos 'n SetUID binêre uitvoering, waareuiddie lêer eienaar se identiteit aanneem, wat spesifieke operasionele toestemmings toeken.suid: Hierdie bespaarde gebruiker ID is belangrik wanneer 'n hoë-regte proses (gewoonlik wat as root loop) tydelik sy regte moet prysgee om sekere take uit te voer, net om later sy aanvanklike verhoogde status te herwin.
Belangrike Nota
'n Proses wat nie onder root werk nie, kan slegs sy euid aanpas om te ooreenstem met die huidige ruid, euid, of suid.
Verstaan set*uid Funksies
setuid: Teen die aanvanklike aannames, verandersetuidhoofsaaklikeuideerder asruid. Spesifiek, vir bevoorregte prosesse, pas ditruid,euid, ensuidaan met die gespesifiseerde gebruiker, dikwels root, wat hierdie ID's effektief versterk as gevolg van die oorheersendesuid. Gedetailleerde insigte kan gevind word in die setuid man bladsy.setreuidensetresuid: Hierdie funksies stel in staat tot die nuanses aanpassing vanruid,euid, ensuid. Hulle vermoëns is egter afhanklik van die proses se regte vlak. Vir nie-root prosesse is aanpassings beperk tot die huidige waardes vanruid,euid, ensuid. In teenstelling, root prosesse of dié metCAP_SETUIDvermoë kan arbitrêre waardes aan hierdie ID's toeken. Meer inligting kan verkry word van die setresuid man bladsy en die setreuid man bladsy.
Hierdie funksionaliteite is nie ontwerp as 'n sekuriteitsmeganisme nie, maar om die beoogde operasionele vloei te fasiliteer, soos wanneer 'n program 'n ander gebruiker se identiteit aanneem deur sy effektiewe gebruiker ID te verander.
Opmerklik, terwyl setuid 'n algemene keuse mag wees vir regte verhoging na root (aangesien dit al die ID's na root aanpas), is dit belangrik om te onderskei tussen hierdie funksies om gebruikers ID gedrag in verskillende scenario's te verstaan en te manipuleer.
Program Uitvoeringsmeganismes in Linux
execve Stelselsoproep
- Funksionaliteit:
execvebegin 'n program, bepaal deur die eerste argument. Dit neem twee array argumente,argvvir argumente enenvpvir die omgewing. - Gedrag: Dit behou die geheue ruimte van die oproeper maar verfris die stapel, hoop, en data segmente. Die program se kode word vervang deur die nuwe program.
- Gebruiker ID Bewaring:
ruid,euid, en aanvullende groep ID's bly onveranderd.euidmag nuanses veranderinge hê as die nuwe program die SetUID bit ingestel het.suidword opgedateer vaneuidna uitvoering.- Dokumentasie: Gedetailleerde inligting kan gevind word op die
execveman bladsy.
system Funksie
- Funksionaliteit: Anders as
execve, skepsystem'n kind proses met behulp vanforken voer 'n opdrag binne daardie kind proses uit metexecl. - Opdrag Uitvoering: Voer die opdrag uit via
shmetexecl("/bin/sh", "sh", "-c", command, (char *) NULL);. - Gedrag: Aangesien
execl'n vorm vanexecveis, werk dit soortgelyk maar in die konteks van 'n nuwe kind proses. - Dokumentasie: Verdere insigte kan verkry word van die
systemman bladsy.
Gedrag van bash en sh met SUID
bash:- Het 'n
-popsie wat beïnvloed hoeeuidenruidhanteer word. - Sonder
-p, stelbasheuidopruidas hulle aanvanklik verskil. - Met
-p, word die aanvanklikeeuidbehou. - Meer besonderhede kan gevind word op die
bashman bladsy. sh:- Besit nie 'n meganisme soortgelyk aan
-pinbashnie. - Die gedrag rakende gebruikers ID's word nie eksplisiet genoem nie, behalwe onder die
-iopsie, wat die bewaring vaneuidenruidgelykheid beklemtoon. - Bykomende inligting is beskikbaar op die
shman bladsy.
Hierdie meganismes, wat in hul werking uniek is, bied 'n veelsydige reeks opsies vir die uitvoering en oorgang tussen programme, met spesifieke nuanses in hoe gebruikers ID's bestuur en bewaar word.
Toetsing van Gebruiker ID Gedrag in Uitvoerings
Voorbeelde geneem van https://0xdf.gitlab.io/2022/05/31/setuid-rabbithole.html#testing-on-jail, kyk dit vir verdere inligting
Geval 1: Gebruik setuid met system
Doel: Verstaan die effek van setuid in kombinasie met system en bash as sh.
C Kode:
#define _GNU_SOURCE
#include <stdlib.h>
#include <unistd.h>
int main(void) {
setuid(1000);
system("id");
return 0;
}
Kompilering en Toestemmings:
oxdf@hacky$ gcc a.c -o /mnt/nfsshare/a;
oxdf@hacky$ chmod 4755 /mnt/nfsshare/a
bash-4.2$ $ ./a
uid=99(nobody) gid=99(nobody) groups=99(nobody) context=system_u:system_r:unconfined_service_t:s0
Analise:
ruideneuidbegin as 99 (nobody) en 1000 (frank) onderskeidelik.setuidstel albei op 1000.systemvoer/bin/bash -c iduit as gevolg van die symlink van sh na bash.bash, sonder-p, paseuidaan om metruidte ooreenstem, wat daartoe lei dat albei 99 (nobody) is.
Geval 2: Gebruik setreuid met system
C Kode:
#define _GNU_SOURCE
#include <stdlib.h>
#include <unistd.h>
int main(void) {
setreuid(1000, 1000);
system("id");
return 0;
}
Kompilering en Toestemmings:
oxdf@hacky$ gcc b.c -o /mnt/nfsshare/b; chmod 4755 /mnt/nfsshare/b
Uitvoering en Resultaat:
bash-4.2$ $ ./b
uid=1000(frank) gid=99(nobody) groups=99(nobody) context=system_u:system_r:unconfined_service_t:s0
Analise:
setreuidstel beide ruid en euid op 1000.systemroep bash aan, wat die gebruikers-ID's behou weens hul gelykheid, en funksioneer effektief as frank.
Geval 3: Gebruik van setuid met execve
Doel: Om die interaksie tussen setuid en execve te verken.
#define _GNU_SOURCE
#include <stdlib.h>
#include <unistd.h>
int main(void) {
setuid(1000);
execve("/usr/bin/id", NULL, NULL);
return 0;
}
Uitvoering en Resultaat:
bash-4.2$ $ ./c
uid=99(nobody) gid=99(nobody) euid=1000(frank) groups=99(nobody) context=system_u:system_r:unconfined_service_t:s0
Analise:
ruidbly 99, maar euid is op 1000 gestel, in ooreenstemming met setuid se effek.
C Kode Voorbeeld 2 (Bel Bash):
#define _GNU_SOURCE
#include <stdlib.h>
#include <unistd.h>
int main(void) {
setuid(1000);
execve("/bin/bash", NULL, NULL);
return 0;
}
Uitvoering en Resultaat:
bash-4.2$ $ ./d
bash-4.2$ $ id
uid=99(nobody) gid=99(nobody) groups=99(nobody) context=system_u:system_r:unconfined_service_t:s0
Analise:
- Alhoewel
euidop 1000 gestel is deursetuid, stelbasheuid terug naruid(99) weens die afwesigheid van-p.
C Kode Voorbeeld 3 (Gebruik bash -p):
#define _GNU_SOURCE
#include <stdlib.h>
#include <unistd.h>
int main(void) {
char *const paramList[10] = {"/bin/bash", "-p", NULL};
setuid(1000);
execve(paramList[0], paramList, NULL);
return 0;
}
Uitvoering en Resultaat:
bash-4.2$ $ ./e
bash-4.2$ $ id
uid=99(nobody) gid=99(nobody) euid=100
Verwysings
tip
Leer en oefen AWS Hacking:
HackTricks Training AWS Red Team Expert (ARTE)
Leer en oefen GCP Hacking:
HackTricks Training GCP Red Team Expert (GRTE)
Leer en oefen Azure Hacking:
HackTricks Training Azure Red Team Expert (AzRTE)
Ondersteun HackTricks
- Kyk na die subskripsie planne!
- Sluit aan by die 💬 Discord groep of die telegram groep of volg ons op Twitter 🐦 @hacktricks_live.
- Deel hacking truuks deur PRs in te dien na die HackTricks en HackTricks Cloud github repos.
HackTricks