Portál AbcLinuxu, 20. dubna 2024 05:00


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: 897×
Odpovědět | Admin

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?

Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

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
Odpovědět | | Sbalit | Link | Blokovat | Admin

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
Odpovědět | | Sbalit | Link | Blokovat | Admin
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
Odpovědět | | Sbalit | Link | Blokovat | Admin
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
Odpovědět | | Sbalit | Link | Blokovat | Admin
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, (c) 1999-2007 Stickfish s.r.o.