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í
×
    dnes 00:22 | Komunita

    Vyjádřeni Software Freedom Conservancy (SFC) k porušování licence AGPLv3 společností Bambu Lab v jejich softwaru Bambu Studio pro 3D tisk. Bambu Studio vychází z PrusaSliceru. Ten zase z Slic3ru. Spuštěn byl projekt baltobu, který kombinuje několik strategií pro řešení problému. SFC zastřeší vývoj svobodné náhrady proprietární knihovny libbambu_networking pomocí reverzního inženýrství a reimplementace, forku OrcaSliceru pro Bambu Lab tiskárny od Paweła Jarczaka a forku celého Bambu Studia pod názvem Viscose.

    Ladislav Hagara | Komentářů: 0
    včera 22:44 | Nová verze

    Správce souborů GNOME Commander (Wikipedie) byl přepsán do Rustu a vydán v nové verzi 2.0.0.

    Ladislav Hagara | Komentářů: 0
    včera 19:44 | Nová verze

    Sway (Wikipedie), dlaždicový (tiling) správce oken pro Wayland kompatibilní s i3, byl vydán ve verzi 1.12. Do vývoje se zapojilo 50 vývojářů. Přehled novinek na GitHubu. Sway 1.12 závisí na wlroots 0.20.0.

    Ladislav Hagara | Komentářů: 0
    včera 16:33 | IT novinky

    Papež Lev XIV. ve své první encyklice Magnifica Humanitas (Skvělé lidství), která se věnuje umělé inteligenci (AI), varoval před dezinformacemi, které AI manipulací s obsahem vytváří. Moc mají podle něj sociální sítě ovládané hrstkou soukromníků. Upozornil také roli digitálních platforem v obchodování s lidmi, které podle něj musí být uznáno jako současná forma otroctví. Papež se také poprvé omluvil za roli, kterou Vatikán sehrál při legitimizaci otroctví, a za to, že jej po staletí neodsoudil.

    Ladislav Hagara | Komentářů: 0
    včera 16:11 | IT novinky

    Český telekomunikační úřad zveřejnil Výroční zprávu za rok 2025 (pdf), která shrnuje jeho hlavní aktivity v oblasti regulace elektronických komunikací, poštovních služeb, digitálních služeb a přípravy na dohled nad umělou inteligencí. Součástí zprávy jsou také data o vývoji trhu, včetně pokračujícího růstu spotřeby mobilních dat a rozšiřování sítí nové generace. Celkový objem přenesených mobilních dat dosáhl v roce 2025 přibližně

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 16:00 | Nová verze

    Tým sdružení CZ.NIC vyvíjející routovacího daemona BIRD oznámil vydání nových verzí 3.3.0 a 2.19.0. Ty přinášejí podporu pro EVPN/VXLAN a automatizaci BGP na základě router advertisementů. Více informací je k dispozici v archivu uživatelského mailing-listu.

    VSladek | Komentářů: 0
    24.5. 04:33 | Nová verze

    Open source software pro úpravu digitálních fotografií LightZone (Wikipedie) byl vydán v nové verzi 5.0.0. LightZone je dnes k dispozici pod licencí BSD. Původně se jednalo o proprietární software vyvíjený společností Light Crafts. Ta v prosinci 2012 souhlasila s uvolněním zdrojových kódů jako open source [Wayback Machine].

    Ladislav Hagara | Komentářů: 0
    23.5. 17:22 | Nová verze

    Byla vydána verze 0.84 telnet a ssh klienta PuTTY (Wikipedie). Podrobnosti v přehledu nových vlastností a oprav chyb a Change Logu.

    Ladislav Hagara | Komentářů: 2
    22.5. 19:44 | IT novinky

    Microsoft představil Azure Linux 4.0 a Azure Container Linux. Na konferenci Open Source Summit North America 2026 organizované konsorciem Linux Foundation a sponzorované také Microsoftem. Azure Linux 4.0 vychází z Fedora Linuxu. Azure Container Linux je založen na projektu Flatcar. Azure Linux (GitHub, Wikipedie) byl původně znám jako CBL-Mariner.

    Ladislav Hagara | Komentářů: 0
    22.5. 12:22 | Zajímavý článek

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 165 (pdf).

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1712 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: BASH grep v proměnný nefunguje

    9.5.2019 18:00 PD321 | skóre: 4
    BASH grep v proměnný nefunguje
    Přečteno: 550×
    Ahoj, mám skript, kde CATem vypisuju soubor a pomocí GREPu výsledek filtruju. Část s GREPama mám uloženou v proměnný.

    prom="| grep srcip=192.168.1.10 | grep dstip=192.168.2.10 | grep dstport=8090"
    cat /mnt/syslog/network/fg-int/fg-int.log $prom


    Pokud to zadám takhle, tak se mi vypíše soubor celej bez ohledu na filtry.

    Když to zadám v celku, bez použití promměný, tak to funguje a vypíše jenom řádky odpovídající filtrům:
    cat /mnt/syslog/network/fw-int.log | grep srcip=192.168.1.10 | grep dstip=192.168.2.10 | grep dstport=8090

    Nevíte kde je chyba? Dík.

    Řešení dotazu:


    Odpovědi

    9.5.2019 18:40 debian+
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje
    Je to o spracovani forend-oveho prikazu backend-om.

    Ak chces aby ti to islo podla teba, tak:
    prom="| grep srcip=192.168.1.10 | grep dstip=192.168.2.10 | grep dstport=8090"
    bash -c "cat /mnt/syslog/network/fg-int/fg-int.log $prom"
    Pozor v prom na obycajne uvodzovky alebo si to uprav.
    9.5.2019 18:45 debian+
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje
    Pokial nechces riesit uvodzovky, tak:
    prom="| grep srcip=192.168.1.10 | grep dstip=192.168.2.10 | grep dstport=8090"
    echo cat /mnt/syslog/network/fg-int/fg-int.log $prom | bash
    xkucf03 avatar 9.5.2019 19:21 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje

    Používat k tomuhle proměnné je prasárna. Sice to za určitých okolností1 můžeš přimět k tomu, aby to fungovalo, ale je to špatně:

    $ x="uname -a"
    $ $x
    Linux osma 4.15.0-48-generic #51-Ubuntu SMP Wed Apr 3 08:28:49 UTC 2019 x86_64 x86_64 x86_64 GNU/Linux
    
    $ x="uname -a | base64"
    $ $x
    uname: nadbytečný operand „|“
    Více informací získáte příkazem „uname --help“.
    
    $ bash -c "$x"
    TGludXggb3NtYSA0LjE1LjAtNDgtZ2VuZXJpYyAjNTEtVWJ1bnR1IFNNUCBXZWQgQXByIDMgMDg6
    Mjg6NDkgVVRDIDIwMTkgeDg2XzY0IHg4Nl82NCB4ODZfNjQgR05VL0xpbnV4Cg==

    Bash umí funkce – a přesně pro tenhle účel se hodí.

    $ mojeFunkce() { uname -a | base64; }
    $ mojeFunkce 
    TGludXggb3NtYSA0LjE1LjAtNDgtZ2VuZXJpYyAjNTEtVWJ1bnR1IFNNUCBXZWQgQXByIDMgMDg6
    Mjg6NDkgVVRDIDIwMTkgeDg2XzY0IHg4Nl82NCB4ODZfNjQgR05VL0xpbnV4Cg==
    

    Funkci pak můžeš používat stejně jako by to byl příkaz/program a propojovat je rourami s dalšími příkazy.

    V tvém případě by to tedy vypadalo nějak takhle:

    prohledejLog() { grep srcip=192.168.1.10 | grep dstip=192.168.2.10 | grep dstport=8090"; }
    cat /mnt/syslog/network/fg-int/fg-int.log | prohledejLog
    

    Roura | je součást syntaxe jazyka – to bys neměl míchat dohromady s daty (obsah proměnných).

    [1] v tom bash -c "…", kde se proměnná vyhodnotí ještě před předáním tomu bashi a poslepuje se z ní kód

    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    Řešení 1× (xkucf03)
    9.5.2019 22:39 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje

    První věc, sice off-topic, ale přece: cat má název podle slova concatenate — používat ho na jediný soubor je zbytečné.

    Teď k tématu: Takové filtrování patří do funkce, ne do proměnné. Mít příkazy v proměnné s sebou pokaždé nese spoustu ošklivosti v podobě buď eval nebo spouštění shellu stylem něco | bash. Ve funkci se dá takový filtr nadefinovat a později spustit.

    my_outdated_ip_address_filter() {
      grep 'srcip=192\.168\.1\.10' |\
      grep 'dstip=192\.168\.2\.10' |\
      grep 'dstport=8090'
    }
    
    my_outdated_ip_address_filter < /mnt/syslog/network/fw-int.log
    
    10.5.2019 16:34 debian+
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje
    Len domam, ze definici funkciu, prikazov a aliasov zistis cez:
    set
    Nieco sa da zistit aj cez napr:
    type less
    10.5.2019 10:29 PD321 | skóre: 4
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje
    Díky debian+, funguje. Ještě bych jenom dodal, proč to mám v proměnný. Příklad jsem maximálně zjednodušil, aby bylo vidět, kde je problém. Ve skutečnosti skript GREPy nemá, ale dostává je ve formě parametru od PHP skriptu, kterej je podle potřeby sestavuje. Ve skriptu se pak nacházej v proměnný $2 (v $1 je uložen název souboru).
    xkucf03 avatar 10.5.2019 11:13 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje
    Ve skutečnosti skript GREPy nemá, ale dostává je ve formě parametru od PHP skriptu, kterej je podle potřeby sestavuje. Ve skriptu se pak nacházej v proměnný $2 (v $1 je uložen název souboru).

    Pak tedy přeji hodně štěstí. Pravděpodobně se ti tam bude dít něco jako SQL injection, akorát se tam nebude injektovat SQL, ale kód v shellu. Takhle tam z toho PHP půjde podstrčit libovolný příkaz… a pokud se to slepuje ze vstupů od uživatele (potenciálního útočníka), tak to není dobré.

    Už jsem takhle viděl třeba WiFi router, který měl ve webovém rozhraní funkci ping – zadal jsi IP adresu a ono to vypsalo výstup příkazu ping. Jenže pokud jsi do políčka s IP adresou dal ty správné uvozovky/apostrofy, tak to nejen spustilo ten ping, ale i tebou zadaný příkaz a vypsalo jeho výstup.

    Vážně by bylo lepší to přepsat s těmi funkcemi a striktně oddělovat data a kód. Kód je spustitelný a měl bys ho mít plně pod kontrolou. Data jsou jen neživé datové struktury, které samy od sebe nic nedělají. Data můžou být třeba seznam položek oddělených znakem konce řádku nebo nulovým bajtem… V Bashi si z toho uděláš pole, bezpečně předáváš dál…

    Ono jde v Bashi sice různě „kouzlit“ a dělat třeba proměnné proměnné (obdoba ukazatelů) nebo proměnné ukazující na funkce/příkazy, které se pak volají, nebo ten dynamicky spouštěný kód přes bash -c "…", co tam máš, a spoustu dalších hacků… ale pokud to vyloženě nepotřebuješ a nevíš přesně, co děláš, tak je lepší se tomu vyhnout a navrhovat ty skripty jednodušeji.

    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    10.5.2019 13:42 PD321 | skóre: 4
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje
    Útoku jsem si vědom. Vstup na HTML stránku je chráněn firewallem a přístup na ní mám jenom já. Pochopitelně se to budu snažit zjednodušit a víc zabezpečit.
    10.5.2019 14:39 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje

    Nic z uvedeného není důvodem, proč by grepy nemohly být ve funkci.

    10.5.2019 16:37 debian+
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje
    Oboznam sa a nauc sa pripadne pouzivat /dev/shm.
    10.5.2019 17:40 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje
    V tom případě bych raději v tom PHP udělal i to filtrování.

    Další možností je využití AWK, které zvládne sestavení podmínky i celé filtrování. Stačí pak jediný proces.

    Pokud trváš na filtrování grepem, nechej si v PHP vygenerovat jednu podmínku na jednom řádku. Bude to flexibilnější.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    10.5.2019 18:45 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: BASH grep v proměnný nefunguje

    Ještě abych upřesnil, jak se lze vyhnout těm ošklivým grepům nebo výrazu pro pipeline v proměnné, tady je drobný příklad.

    Co takhle mít skript, který dostane v "$1" název souboru a pak budou následovat regulární výrazy pro grep? Skript z regulárních výrazů automaticky sestaví filtrovací pipeline a soubor skrz ni protlačí. Zavolá se třeba takto:

    ./filters.sh /mnt/syslog/network/fw-int.log \
                 'srcip=192\.168\.1\.10' \
                 'dstip=192\.168\.2\.10' \
                 'dstport=8090'
    

    A celý filters.sh může vypadat například takto:

    set -e -o pipefail -u
    
    my_magic_filter() {
      local -r filters_name="$1"
      local -rn filters="$filters_name"
      local -ri current_filter="$2"
      local -ri last_filter="$(("${#filters[@]}" - 1))"
      if ((current_filter == last_filter)); then
        grep "${filters[current_filter]}"
      else
        grep "${filters[current_filter]}" |\
        my_magic_filter "$filters_name" "$((current_filter + 1))"
      fi
    }
    
    declare -r file_name="$1"
    shift
    declare -ar array_of_filters=("$@")
    
    my_magic_filter 'array_of_filters' 0 < "$file_name"
    

    Tam^^^ pochopitelně zoufale chybí ošetření chyb, například (1) špatného počtu a typu parametrů pro my_magic_filter(), (2) špatných indexů pole a podobně. Pro obecnější nasazení je třeba tohle doladit.

    Jak už tady bylo řečeno, fakt je asi lepší udělat to přímo v PHP (nebo snad možná v awk). Já osobně bych to asi nakódil v PHP, kdybych musel. Bude to efektivnější než spouštět takhle Bash na každý požadavek.

    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.