Portál AbcLinuxu, 14. května 2025 01:15
Řešení dotazu:
char cmd[256]; sprintf(cmd, "shutdown %d", time); result = system(cmd);
system()
je poměrně nebezpečná hračka a její neuvážené použití snadno vytváří bezpečnostní chyby. Nemám moc dobrý pocit, když ji vidím používat někoho, kdo se potřebuje ptát na takhle elementární obraty.
%d
je k %s
sakra blízko. Stačí, že si autor vzpomene, že chce použít plné možnosti zadání času pro shutdown
.
sprintf
by mal autor pouzit snprintf
.
char cmd[256]; snprintf(cmd, 256, "shutdown %d", time); result = system(cmd);což je nesmysl a spíš bych čekal že si pak kus toho čísla ustřihne a shutdown se provede v jiný čas, což by mohlo být větší bezpečnostní riziko :) strncpy není něco jako "bezpečná verze strcpy" v oblasti security, spíš brání nechtěným chybám v oblasti dočasné programátorovy stupidity která občas potká každého z nás. I když je nepochybně mnoho případů, kdy je vhodné ji použít, hlavně proto, aby se člověk musel zamyslet, jak dlouhý ten vstup vlastně může být. Pokud se ovšem zamyslí a řekne si, že nejlepší bude tam dát strlen(vstup) a má to teda bezpečné, protože to psali na abclinuxu, tak jsme tam, jde jsme byli :D
GNU funkciA v tom je háček, zrušíte tak přenositelnost programu a pak nemá teda ani cenu zabývat se velikým intem, budete na tom stejně.
char cmd[sizeof("shutdown %d") + sizeof(unsinged) * 3];
sprintf(cmd, "shutdown %d", time);
...
...
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.