Получение полезной нагрузки с пакетом TCP от Python и Ipparket

StackOverflow https://stackoverflow.com/questions/5864632

  •  28-10-2019
  •  | 
  •  

Вопрос

Я смог найти пакеты, представляющие интерес, используя код на основе этого примера:

Как я могу отфильтровать файл PCAP по конкретному протоколу с помощью Python?

Следующим ребенком из пакета TCP являются фактические данные:

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

Это распечатывает данные пакетов, такие как проводная акула и показывает версии HEX и ASCII. Однако до сих пор я не смог найти способ просто получить содержимое гекса. Я знаю, что могу манипулировать выводом для печати, но я решил, что должен быть способ получить данные в шестнадцатеричной форме ...

Я просмотрел образцы, но никто этого не сделал. Кто -нибудь знает правильный путь?

Это было полезно?

Решение

Вы можете использовать packet.get_data_as_string() Чтобы получить сырые байты, а затем отобразить его как вам нравится. Я воспроизвел выход «шестнадцатеричная колонна», произведенный print child. Анкет Должно быть легко настроить, чтобы произвести колонны 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)

Выход:

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  
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top