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 23:11 | Komunita

    Řídící výbor GCC schválil rozšíření frontendů GCC o WebAssembly.

    Ladislav Hagara | Komentářů: 0
    včera 21:00 | Nová verze

    Po 9 týdnech vývoje od vydání Linuxu 7.0 oznámil Linus Torvalds vydání Linuxu 7.1. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a časem také na Linux Kernel Newbies.

    Ladislav Hagara | Komentářů: 0
    včera 13:33 | Zajímavý software

    Cheat Engine (Wikipedie) je s verzí 7.7 k dispozici už také pro Linux. Jedná se o proprietární skener/debugger paměti používaný především k cheatování v počítačových hrách.

    Ladislav Hagara | Komentářů: 0
    13.6. 15:22 | IT novinky

    Vláda USA nařídila společnosti Anthropic pozastavit přístup k modelům Fable 5 a Mythos 5 pro všechny cizince, včetně zaměstnanců Anthropicu.

    Ladislav Hagara | Komentářů: 7
    13.6. 02:22 | Nová verze

    Společnost Murena představila (YouTube) novou verzi 4.0 mobilního operačního systému /e/OS (Wikipedie) založeného na Androidu a LineageOS bez aplikací a služeb od Googlu.

    Ladislav Hagara | Komentářů: 0
    12.6. 16:33 | Bezpečnostní upozornění

    V Arch User Repository (AUR) bylo kompromitováno přes 400 opomíjených balíčků (jejich seznam). Útočník do nich začlenil škodlivý npm balíček atomic-lockfile, který krade citlivá data uživatelů. Publikována byla předběžná analýza spouštěného malwaru deps.

    Ladislav Hagara | Komentářů: 13
    12.6. 11:33 | Nová verze

    Homebrew, správce balíčků nejen pro macOS, byl vydán ve verzi 6.0.0 (seznam změn). Hlavními novinkami jsou bezpečnostní mechanismus tap trust kvůli důvěryhodnosti závislostí, vylepšení sandboxingu na Linuxu, interní JSON API nebo zlepšení výkonu.

    |🇵🇸 | Komentářů: 0
    12.6. 03:33 | Bezpečnostní upozornění

    Byla nalezena a 9. června opravena kritická zranitelnost ve FreeBSD v Kernel TLS (KTLS). Pojmenována byla Bumsrakete (FreeBSD-SA-26:26.ktls, CVE-2026-45257). Lokální neprivilegovaný uživatel může přepisovat soubory, ke kterým má právo pouze pro čtení. Přepsáním setuid binárky a jejím spuštěním může získat roota. Na všech verzích od verze 13.0 vydané v dubnu 2021.

    Ladislav Hagara | Komentářů: 2
    11.6. 14:11 | Komunita

    Vývojáři open source operačního systému ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, se na síti 𝕏 pochlubili, že ReactOS zvládne počítačovou hru Half-Life.

    Ladislav Hagara | Komentářů: 5
    11.6. 10:44 | Nová verze

    Byla vydána nová verze 4.8 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

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


    Dotaz: Netcat a Windows/Unix line feed

    Zdeněk Zámečník avatar 5.8.2010 23:38 Zdeněk Zámečník | skóre: 26
    Netcat a Windows/Unix line feed
    Přečteno: 952×

    Neúspěšně bojuji s CR+LF vs LF. Na serveru poslouchám netcatem a na něj se připojuji telnetem z Windows. Problém je v tom, že windows mi posílá CR+LF, ale netcat očekává zakončení řádku pouze LF. Důsledek je takový, že když výstup netcatu sypu rourou někam dál, pošlou se mi do ní data až po přerušení spojení.

    Já ovšem potřebuji data posílat okamžitě, CR+LF nahradit LF...

    Stojím na tomto bodě:

    nc -l -k -t -p 2000 | sed -e 's/\r/\r\n/g'

    Zajímavé je, že když výstup přesměruji do souboru, třeba takto:

    nc -l -k -t -p 2000 > output.log
    tak se tam vše zapisuje okamžitě. Resp. pokud si jej otevřu ve vimu, je to tam. Cat apod. neukáže nic...

    Poradí mi někdo, jak toto chování/problém vyřešit nebo obejít?

    Odpovědi

    Zdeněk Zámečník avatar 6.8.2010 01:09 Zdeněk Zámečník | skóre: 26
    Rozbalit Rozbalit vše Re: Netcat a Windows/Unix line feed

    Trošku jsem pokročil:

    nc -l -p 2000 | tr '\n\r' '\n'
    kupodivu funguje přesně, jak jsem chtěl.

    Průšvih je, že chci netcatem volat skript, který vstup zpracuje a podle toho vyhodí nějaký výstup, takže něco ve stylu:

    nc -l -p 2000 -e read.sh

    read.sh:

    #!/bin/bash
    while true; do
      read input
      echo $input>input.log
      echo "Recorded: $input"
    done
    

    Ovšem tím jsem s problémem zase na začátku, protože opět nevím, jak ten vstup v read.sh vzít a prohnat ho něčím co ho zkonvertuje CR+LF na LF.

    6.8.2010 01:39 zulu
    Rozbalit Rozbalit vše Re: Netcat a Windows/Unix line feed
    sed i tr máš blbě. Ten vstup v bashi můžeš upravit takhle
    input=${input%$'\r'}
    Zdeněk Zámečník avatar 6.8.2010 01:47 Zdeněk Zámečník | skóre: 26
    Rozbalit Rozbalit vše Re: Netcat a Windows/Unix line feed
    Co je na nich špatně? Tohle mi nepomůže, mám problém načíst už samotný input, pak už je sranda s ním manipulovat. Read totiž očekává zakončení řádky LF, sice má přepínač -d (delimiter), jenže ten neumí escape sekvence...
    6.8.2010 07:04 mkmm | skóre: 11
    Rozbalit Rozbalit vše Re: Netcat a Windows/Unix line feed
    Co zkusit jinou verzi netcatu? Treba ncat, ktery je soucasti nmap, ma prepinac na konverzi CRLF a existuje i pro windows.
    6.8.2010 07:11 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Netcat a Windows/Unix line feed
    Hmm, zdá se že vidět je věřit? Co když se vám vše vypisuje ale kvůli tomu \r to nevidíte v konzoli.

    Za prvé
    sed -e 's/\r/\r\n/g'
    
    tak úplně \r neodstraní. Asi spíš chcete
    sed 's/\x0d$//g'
    
    Popřípadě totéž se sed -u, abyste ještě nenarazil na problém bufferování výstupu a data se vypisovala opravdu po řádcích.

    Jinak lépe než čachrovat s vimem a catem je lepší použít "od":
    $ echo -ne 'aaaa\r\n' | sed 's/\x0d$//g' | od -t x1
    0000000 61 61 61 61 0a
    0000005
    
    In Ada the typical infinite loop would normally be terminated by detonation.
    Zdeněk Zámečník avatar 12.8.2010 11:59 Zdeněk Zámečník | skóre: 26
    Rozbalit Rozbalit vše Re: Netcat a Windows/Unix line feed

    Máte pravdu. Prohnal jsem to čistě "od" a zjistil jsem, že řetězec je zakončen samotným CR (x0d), zkoušel jsem tedy

    netcat -l -p 2000 | sed -u 's/\x0d/\x0a/g'
    což mi průběžně nevypisuje nic, až když se přeruší spojení, tak se vypíše vše najednou.

    Druhý pokus ve formě

    netcat -l -p 2000 | tr '\r' '\n'
    vypisuje pěkně průběžně.

    Ovšem pokud kterýkoliv z těchto dvou výstupů přesměruji do souboru, tak se mi v obou případech zapíše do souboru až po přerušení spojení. Začínám mít obavy, že se standardními nástroji v Linuxu to dohromady nedám. Možná by bylo nejjednoduší to celé napsat v Pythonu...

    12.8.2010 21:25 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Netcat a Windows/Unix line feed
    což mi průběžně nevypisuje nic, až když se přeruší spojení, tak se vypíše vše najednou.

    Zní to jako problém s I/O buffery. Ve skutečnosti to není "po přerušení spojení" ale něco jako 4kb dat.
    In Ada the typical infinite loop would normally be terminated by detonation.

    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.