用python进行USB映射

Nit*_*ian 5 python wireshark

在阅读一些CTF写作时,我遇到了这个脚本

#!/usr/bin/env python
import struct
import Image
import dpkt

INIT_X, INIT_Y = 100, 400

def print_map(pcap, device):
    picture = Image.new("RGB", (1200, 500), "white")
    pixels = picture.load() 

    x, y = INIT_X, INIT_Y

    for ts, buf in pcap:
        device_id, = struct.unpack("b", buf[0x0B])

        if device_id != device:
            continue

        data = struct.unpack("bbbb", buf[-4:])

        status = data[0]
        x = x + data[1]
        y = y + data[2]

        if (status == 1):
            for i in range(-5, 5):
                for j in range(-5, 5):
                    pixels[x + i , y + j] = (0, 0, 0, 0)
        else:
            pixels[x, y] = (255, 0, 0, 0)
    picture.save("riverside-map.png", "PNG")

if __name__ == "__main__":

    f = open("usb.pcap", "rb")
    pcap = dpkt.pcap.Reader(f)
    print_map(pcap, 5)
    f.close()
Run Code Online (Sandbox Code Playgroud)

当我在我的usb.pcap上运行它时,我收到此错误:

 Traceback (most recent call last):
      File "test.py", line 39, in <module>
        print_map(pcap, n)
      File "test.py", line 31, in print_map
        pixels[x, y] = (255, 0, 0, 0)
  IndexError: image index out of range
Run Code Online (Sandbox Code Playgroud)

为什么会这样?

Ste*_*hen 3

根据 usb.pcap 文件中的数据集,您可能需要调整 INIT_X 和 INIT_Y 变量。问题是 struct.unpack 返回一个带符号的值,因此如果数据超过 127,那么它会显示为负数,并且超出了数组边界。如果数据确实始终为正值,您可以对其进行测试并将其强制为正值。就像是:

data = [item + 256 if item < 0 else item for item in data]
Run Code Online (Sandbox Code Playgroud)