使用Scapy从Mac OSX上的数据包获取信号强度

时间:2018-07-30 14:17:14

标签: macos wifi scapy rssi

背景

我正在尝试从接收到的数据包中获取RSSI。我知道它们在Radiotap标头中可用,但不幸的是,我无法嗅探其中包含Radiotap标头的任何数据包。

我确实从parsePacket找到了scapy-rssi方法,该方法似乎只能过滤出包含带有RSSI的Radiotap标头的数据包(如果我没记错的话)。

我在以下代码中使用了该方法:

def parsePacket(pkt):
  if pkt.haslayer(scapy.all.Dot11):
    if pkt.addr2 is not None:
      # check available Radiotap fields
      field, val = pkt.getfield_and_val("present")
      names = [field.names[i][0] for i in range(len(field.names)) if (1 << i) & val != 0]
      # check if we measured signal strength
      if "dBm_AntSignal" in names:
        # decode radiotap header
        fmt = "<"
        rssipos = 0
        for name in names:
          # some fields consist of more than one value
          if name == "dBm_AntSignal":
            # correct for little endian format sign
            rssipos = len(fmt)-1
          fmt = fmt + self.radiotap_formats[name]
        # unfortunately not all platforms work equally well and on my arm
        # platform notdecoded was padded with a ton of zeros without
        # indicating more fields in pkt.len and/or padding in pkt.pad
        decoded = struct.unpack(fmt, pkt.notdecoded[:struct.calcsize(fmt)])
        return pkt.addr2, decoded[rssipos]

def packetCallback(pkt):
  parsed = parsePacket(pkt)
  if parsed:
    print(parsed)

sniff("en1", prn=packetCallback)  #en1 is a wlan interface on my OSX

不幸的是,该功能未输出任何内容-因此,没有数据包包含Radiotap标头。我尝试使用sniff("en1mon", prn=packetCallback)激活监视模式,但是没有任何进展。


主要问题:

我还发现,在Mac OSX的en1接口无法访问Dot11标头的地方,是这样吗?如果是这样,那我如何从OSX上的数据包中获取RSSI值?

谢谢!

1 个答案:

答案 0 :(得分:1)

几件事:

然后,您可能希望直接使用packet[Radiotap].dBm_AntSignal,如果不是None,则为负值,而不是整个parsePacket。

最后,在OSX上,您可能需要使用sniff([...], monitor=True)以确保正确接收原始数据包