2011-09-06 14 views
8

Ho usato entrambi, e concludo che posso leggere i dati html dalle pagine web con tcpflow ma non posso farlo con tcpdump. Il meglio che ottengo è un brutto testo ASCII con molti simboli del periodo.tcpdump vs tcpflow (o "perché non è tcpdump i dati del pacchetto ASCII leggibili dall'uomo?")

La mia comprensione è che tcpdump non riassembla i pacchetti, mentre lo fa tcpflow. Ma se questa fosse la differenza chiave, i dati a pacchetto di tcpdump non sarebbero ancora leggibili dall'uomo - solo in blocchi più piccoli? Il problema è che tcpdump è limitato ad ASCII e gran parte del traffico di rete è codificato in UTF-8?

Sono un novellino di analisi/programmazione di rete, quindi perdonami se mi manca qualcosa di ovvio.

+3

Basta usare wireshark per leggere i file di acquisizione tcpdump e quindi selezionare un pacchetto nella sessione in questione. È possibile utilizzare "Analizza"> "Segui flusso TCP" per ottenere un dump ASCII dell'intero flusso. –

risposta

11

Per ottenere i dati crittografati, è necessario utilizzare tcpdump con l'opzione tcpdump –A (lettera a). Trasferisce il testo senza intestazioni e viene utilizzato principalmente per le pagine Web. Quindi otteniamo facilmente la pagina di risposta.

Penso che vi stiate confondendo tra un livello applicazione e un pacchetto del livello di trasporto.

Non so circa tcpflow ma cattura tcpdump l'intero pacchetto (compresa intestazione e tutte le altre cose), non solo i dati data.The html che si sta citano sarebbe nella parte di dati di un TCP/UDP/pacchetto ICMP qualsiasi cosa tu stia usando e quindi ha bisogno che tu capisca la struttura del pacchetto tcp/udp/icmp ...

Catturo questo pacchetto sulla mia macchina e i dati HTML sono chiaramente visibili, devi scrivere script per ottenere dall'output con una conoscenza della struttura dei pacchetti.

16:15:17.968325 IP 172.31.9.84.80 > 172.31.9.177.56559: P 2575928381:2575928808(427)  
ack 65285447 win 1716 <nop,nop,timestamp 21031622 15165633> 
0x0000: 4500 01df 66fd 4000 4006 66d8 ac1f 0954 [email protected]@.f....T 
0x0010: ac1f 09b1 0050 dcef 9989 8c3d 03e4 2d47 ..... P.....=..-G 
0x0020: 8018 06b4 1a2a 0000 0101 080a 0140 eac6  .....*[email protected] 
0x0030: 00e7 68c1 4854 5450 2f31 2e31 2032 3030 ..h.HTTP/1.1.200 
0x0040: 204f 4b0d 0a44 6174 653a 2046 7269 2c20 .OK..Date:.Fri,. 
0x0050: 3130 204a 756c 2032 3030 3920 3130 3a32 10.Jul.2009.10:2 
0x0060: 303a 3136 2047 4d54 0d0a 5365 7276 6572 0:16.GMT..Server 
0x0070: 3a20 4170 6163 6865 2f32 2e30 2e35 3220 :.Apache/2.0.52. 
0x0080: 2852 6564 2048 6174 290d 0a4c 6173 742d (Red.Hat)..Last- 
0x0090: 4d6f 6469 6669 6564 3a20 4672 692c 2031 Modified:.Fri,.1 
0x00a0: 3020 4a75 6c20 3230 3039 2030 393a 3331 0.Jul.2009.09:31 
0x00b0: 3a30 3420 474d 540d 0a45 5461 673a 2022 :04.GMT..ETag:." 
0x00c0: 3266 6231 3333 2d37 372d 6131 3935 3436 2fb133-77-a19546 
0x00d0: 3030 220d 0a41 6363 6570 742d 5261 6e67  00"..Accept-Rang 
0x00e0: 6573 3a20 6279 7465 730d 0a43 6f6e 7465 es:.bytes..Conte 
0x00f0: 6e74 2d4c 656e 6774 683a 2031 3139 0d0a nt-Length:.119.. 
0x0100: 4b65 6570 2d41 6c69 7665 3a20 7469 6d65 Keep-Alive:.time 
0x0110: 6f75 743d 3135 2c20 6d61 783d 3130 300d out=15,.max=100. 
0x0120: 0a43 6f6e 6e65 6374 696f 6e3a 204b 6565 .Connection:.Kee 
0x0130: 702d 416c 6976 650d 0a43 6f6e 7465 6e74 p-Alive..Content 
0x0140: 2d54 7970 653a 2074 6578 742f 6874 6d6c -Type:.text/html 
0x0150: 3b20 6368 6172 7365 743d 4953 4f2d 3838  ;.charset=ISO-88 
0x0160: 3539 2d31 0d0a 0d0a 3c68 746d 6c3e 0a0a 59-1....<html>.. 
0x0170: 3c62 6f64 793e 0a49 6e64 6961 6e20 696e <body>.Indian.in 
0x0180: 7374 6974 7574 6520 6f66 2074 6563 686e stitute.of.techn 
0x0190: 6f6c 6f67 7920 2e2e 2e2e 2e20 7468 6973  ology.......this 
0x01a0: 2069 7320 7468 6520 7465 7374 2070 6167 .is.the.test.pag 
0x01b0: 652e 0a3c 4120 6872 6566 3d22 6164 2e68 e..<A.href="ad.h 
0x01c0: 746d 6c22 3e61 6263 643c 2f41 3e0a 0a3c tml">abcd</A>..< 
0x01d0: 2f62 6f64 793e 0a3c 2f68 746d 6c3e 0a   /body>.</html>. 

ultimi 7-8 righe descrivono i dati HTML.

utilizzare -s0 per acquisire l'intero fotogramma e -X per stampare in formato ASCII leggibile sopra ASCII.

Per ottenere i dati crittografati, è necessario utilizzare TCPDUMP con l'opzione -A (maiuscola a). Trasferisce il testo senza intestazioni e viene utilizzato principalmente per le pagine Web. Quindi otteniamo facilmente la pagina di risposta.

Per esempio:

Chiedo index.html a 172.31.9.84 alla porta 80

Poi ho chiesto GET/index.html (una pagina di esempio che contiene solo testo “Indian Institute of Technology questo è la pagina di prova”)

in questo momento in cui ho catturato i pacchetti ho qualcosa come:

Request: 

18:10:42.387426 IP 172.31.9.177.42943 > 172.31.9.84.80: 
P 1:15(14) ack 1 win 46 <nop,nop,timestamp 6644101 353753635> 
[email protected]@........T...P^R.Mb.L.....ke..... 
.ea....#GET /index.html 

Response: 

18:10:42.388127 IP 172.31.9.84.80 > 172.31.9.177.42943: P 1:53(52) 
ack 15 win 1448 <nop,nop,timestamp 353758368 6644101> 
[email protected]@.8m..T.. ..P..b.L.^R.[....d...... 
.....ea.<html> 

<body> 
Indian institute of technology this is the test page 
</body> 
</html> 
+0

Grazie mille Udit. Sì, mi stavo confondendo tra i due livelli del modello OSI. –

+1

Ancora meglio, usa 'tcpdump -w' per registrare completamente i pacchetti in un file, e successivamente' tcpdump -r' per ripristinarli e trovare le migliori opzioni da riga di comando per iterazione per vedere i dettagli che vuoi vedere. –

+0

'I dati html che stai citando sarebbero nella parte dati di un pacchetto tcp/udp/icmp' Realmente? Pensi sia probabile che stia visitando un sito Web che risponde con HTML incapsulato in ... pacchetti ICMP? Improbabile. 'è necessario scrivere script per ottenerlo dall'output con una conoscenza della struttura dei pacchetti 'Non è vero. Potresti semplicemente usare Wireshark. –

2

quando si cerca di ottenere i dati HTTP usando tcpdump, vedrete c testo in ASCII se si applica l'opzione -A. Tuttavia, i dati HTTP sono quasi sempre compressi con la modalità gzip o altro. Lo si può vedere nelle intestazioni:

Content-Encoding: gzip, comprimere, bzip2

Così, tcpdump sarà in uscita nel vostro schermo diversi byte e sono i dati compressi !!! Sarà necessario utilizzare tshark o wireshark per visualizzare dati flat. Quindi il tuo problema non è UTF8.

È possibile testare la visualizzazione dei dati tcpdump disabilitando il modulo di svuotamento nel server Web Apache.

Spero che questo aiuto.

+0

Questo aiuta. Grazie Eriberto. –