当前位置:   article > 正文

PyShark入门(3):capture对象

pyshark filecapture

原文链接:http://zodiacg.net/2016/07/in...

本系列文章译自thePacketGeek的系列文章。原创翻译,转载请注明出处。

我们已经了解了如何使用 FileCaptureLiveCapture 模块来捕获数据包,下面我们来看一下如何使用返回的 capture 对象。

  1. dir(cap)
  2. Out[3]:
  3. ['apply_on_packets',
  4. 'close',
  5. 'current_packet',
  6. 'display_filter',
  7. 'encryption',
  8. 'input_filename',
  9. 'next',
  10. 'next_packet']

(简洁起见以上列表经过了精简)

这些是我认为比较有用的方法和属性,其它大多数是用于调试或者捕获过程内部使用。 display_filterencryptioninput_filename 属性是之前传递给 FileCapture 或者 LiveCapture 的值。

此处真正强大的是apply_on_packets()next()方法。next()方法使得 capture 对象可以通过for循环进行遍历。
apply_on_packets() 方法是另一种遍历数据包的方式,它接受一个函数作为参数并将之作用于所有的数据包。

  1. >>> cap = pyshark.FileCapture('test.pcap', keep_packets=False)
  2. >>> def print_highest_layer(pkt)
  3. ...: print pkt.highest_layer
  4. >>> cap.apply_on_packets(print_highest_layer)
  5. HTTP
  6. HTTP
  7. HTTP
  8. HTTP
  9. HTTP
  10. ... (truncated)

这个方法也可以用于打印之外的功能,例如将数据包添加入一个列表进行其它处理。下面的脚本会将所有的数据包加入到一个列表中并打印总数:

  1. import pyshark
  2. def get_capture_count():
  3. p = pyshark.FileCapture('test.cap.pcap', keep_packets=False)
  4. count = []
  5. def counter(*args):
  6. count.append(args[0])
  7. p.apply_on_packets(counter, timeout=100000)
  8. return len(count)
  9. print get_capture_count()

上一篇:PyShark入门(2):FileCapture和LiveCapture模块
下一篇:PyShark入门(4):capture对象

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/156848?site
推荐阅读
相关标签
  

闽ICP备14008679号