Portál AbcLinuxu, 11. května 2025 00:39

Dotaz: int system (const char str) nevracia navratovu hodnotu

9.5.2011 12:11 xsustek | skóre: 6
int system (const char str) nevracia navratovu hodnotu
Přečteno: 208×
Odpovědět | Admin
V ramci programu napisaneho v C volam pomocou funkcie system jeden perlovsky skript a potrebujem ziskat jeho navratovu hodnotu. Avsak aj ked skript skonci s nenulovou navratovou hodnotou - funkcia system() v C kode vracia stale nulu.

Je nejak mozne ze funkcia zachytava navratovu hodnotu samotneho perlu ako interpreta a preto vzdy konci uspesne s 0? Je nejake ine vysvetlenie, pripadne napad ako to napravit?

Dik

Řešení dotazu:


Nástroje: Začni sledovat (1) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

9.5.2011 12:43 kuka
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Odpovědět | | Sbalit | Link | Blokovat | Admin
Melo by to vratit exit code posledniho volaneho programu. Navratova hodnota skriptu je presne co?
9.5.2011 12:52 xsustek | skóre: 6
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Navratova hodnota perl skriptu je 2. System () vracia 0. Prave preto to nechapem, lebo chyba musi byt niekde pri odovzdavani navratovej hodnoty.
9.5.2011 13:20 chochi | skóre: 29 | Praha
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Odpovědět | | Sbalit | Link | Blokovat | Admin
No to zalezi co myslis vyrazem "navratovou hodnotou" v perlu. Pokud je to hodnota posledniho statementu, tak neni vracena zdana chyba (prikaz vrati navratovou hodnotu 0), pokud je to hodnota vracena pomoci funkce exit, tak pak tato hodnota je nastavena jako navratova hodnota celeho programu.:

$ echo 'int main() { printf("Ret: %i\n", system("perl -e \"exit(17);\"") >> 8); }' | gcc -w -x c - && ./a.out 
Ret: 17
$ echo 'int main() { printf("Ret: %i\n", system("perl -e \"17;\"") >> 8); }' | gcc -w -x c - && ./a.out 
Ret: 0
9.5.2011 14:01 xsustek | skóre: 6
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Champem ,ale myslim, ze v to je vratene exit(om). Pripajam ukazku.
suster@ubuntu-l1:~/Production/TSMReport$ ./tsm.pl
...(nejaky vystup)...
suster@ubuntu-l1:~/Production/TSMReport$ echo $?
1
suster@ubuntu-l1:~/Production/TSMReport$ ./tsm
...(nejaky vystup)...
suster@ubuntu-l1:~/Production/TSMReport$ echo $?
0


cat tsm.c
int main(int argc, char *argv[])
{
   int i;
   char run_this [] = "perl /home/jsuster/Production/TSMReport/tsm.pl";
   setuid( 0 );
   return system(run_this);
}

Řešení 1× (xsustek (tazatel))
9.5.2011 14:11 chochi | skóre: 29 | Praha
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Tak to uz je jasne. system nevraci jen navratovou hodnotu ale i dalsi informaci (zda byl program signalovan, ci ne, atd.). Tenhle priklad odpovida:

$ echo 'int main() { return 256; }' | gcc -w -x c - && ./a.out ; echo $?
0
Navratovy kod se da zjistit pomoci makra WEXITSTATUS (doporucuju se podivat na "man 2 wait"). Uplne nejlepsi je neco takoveho:

status = system(command);
if(WIFEXITED(status)) {
  printf("Command %s exited with return code %i\n", command, WEXITSTATUS(status));
} else {
  printf("Command %s ended unexpectedly\n", command,);
}
9.5.2011 14:30 kuka
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
exit code musi byt v rozsahu 0-255 (POSIX). 256 se zachova jako 0, 257 jako 1 atd. - nevim jestli je to dane normou nebo to treba smi spadnout, typicky to ale projde a vraci se hodnota odpovidajici nejnizsim 8 bitum.
9.5.2011 15:13 xsustek | skóre: 6
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Toto je super. Uz som si myslel, ze to mam vyriesene. Avsak zda sa mi, ze makro WEXITSTATUS(status)) vracia bud 0 alebo 1 podla uspesnosti. Ja by som vsak potreboval zachytit cely navratovy kod skriptu. Nielen zistit ci skoncil chybne alebo nie. Ten kod sa tam musi niekde stratit a nechapem kde.
Řešení 1× (xsustek (tazatel))
9.5.2011 16:03 chochi | skóre: 29 | Praha
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Me vzdy fungovalo spravne. Nejlespi by bylo si tam dopsat nejake debug hlasky - jakou hodnotu vrati volani system() a co s ni provede to makro. A nebo to pustit pres strace:

$ echo 'int main() { printf("Ret: %i\n", system("perl -e \"exit(17);\"") >> 8); }' | gcc -w -x c - && strace -f ./a.out 
...
[pid 11921] exit_group(17)              = ?
Process 11920 resumed
Process 11921 detached
<... waitpid resumed> [{WIFEXITED(s) && WEXITSTATUS(s) == 17}], 0) = 11921
...
9.5.2011 19:19 xsustek | skóre: 6
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Diky moc. Uz mi to funguje. Len som namiesto WEXITSTATUS vypisoval WIFEXITED. :). Dik za pomoc.
9.5.2011 14:32 kuka
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Urcite ten skript dela v obou pripadech totez a bezi ve "stejnem prostredi"? Nema napriklad tsm nastavena prava roota (mate me to setuid v programu, ktere zrejme nic nedela, ale k necemu tam asi puvodne melo byt)?
9.5.2011 14:56 xsustek | skóre: 6
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Ano, ucel programu je len spustin iny s suid. Ale pri danej ukazke tam suid nebol v pristupovych pravach. A ak by aj bol, myslim, ze by tam problem nemal byt. Program snad nevrati inu navratovu hodnou vzhladom na to ci je alebo nieje suid aktivny, nie?
9.5.2011 15:03 kuka
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
No to snad zalezi na tom, co to je za program?! Obvykle nenulove navratove kody znamenaji chybu, takze by jiste mohl existovat program, ktery s nizsimi pravy napr. nevidi potrebne soubory a vrati nenulovou hodnotu, zatimco s pravy roota skonci uspesne a vrati nulovou hodnotu. Cimz nerikam, ze je to nutne tento pripad, nicmene na pravech obecne zalezi, jinak by zadna prava nemusela existovat...
10.5.2011 01:09 zulu
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Minule ti někdo psal, že si suid-wrapper nemáš psát sám.
cp /usr/bin/vim perl
PATH=.:$PATH ./tsm
10.5.2011 06:25 xsustek | skóre: 6
Rozbalit Rozbalit vše Re: int system (const char str) nevracia navratovu hodnotu
Napadlo ma, ze som vlasne nerozmyslal ci by sa nedalo uplne to iste urobit sudom - chcem len aby nemal uzivatel pristup k mojmu skriptu ale zaroven ho mohol spustit. Myslite ze sudo je spravna cesta?

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.