Domanda

Sono stato in grado di trovare pacchetti di interesse usando il codice in base a questo esempio:

Come posso filtrare un file PCAP per protocollo specifico usando Python?

Il bambino successivo dal pacchetto TCP è i dati effettivi:

   if isinstance(child1, TCP):
        if child1.get_th_dport() == 80:
           x = child1.child()
           print x

Questo stampa i dati dei pacchetti come lo squalo filo e mostra versioni esadecimale e ASCII. Tuttavia non sono stato finora in grado di trovare un modo per ottenere semplicemente il contenuto di esadecimazione. So di poter manipolare l'output stampabile ma ho pensato che ci fosse un modo per ottenere i dati nella forma esadecimale ...

Ho guardato attraverso i campioni ma nessuno sembra farlo. Qualcuno sa il modo giusto?

È stato utile?

Soluzione

Puoi usare packet.get_data_as_string() Per ottenere i byte grezzi, quindi visualizzarlo come preferisci. Ho replicato l'uscita "colonna esagonale" prodotta da print child. Dovrebbe essere facile da modificare per produrre anche colonne ASCII:

def display_hex(pkt, cols=8):
    size = cols * 4
    data = ''.join('%02x' % ord(b) for b in pkt.get_data_as_string())
    for i in range(0, len(data), size):
        for j in range(0, size, 4):
            print data[i+j:i+j+4],
        print

if isinstance(child, TCP):
    display_hex(child)

Produzione:

1703 0103 b0b1 9387 be4e fe00 9230 6192
e3bb 217e c1cb 8511 556f f986 4f31 542d
15c6 f42e f3bb 93d5 cf33 f126 c174 dbc4
... snip ...
8b1d 8707 96d6 7a18 2aab fd0b 48ee c4eb
b7d8 a67f 8bc0 597d 1044 a076 1a9e 24ba
959b fda3 1adb 2384 669c e6c8 c3b5 bef4
1189 eda8 3e  
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top