QQ叫紫珊 发表于 2018-8-6 11:05:28

SendPkt快速入门[Python]

SendPkt快速入门  作者:
  gashero
  电邮:
  harry.python@gmail.com
  原文地址:
  http://gashero.yeax.com/?p=26
  项目主页:
  http://sendpkt.googlecode.com
  日期:
  2007-10-03
  版本:
  sendpkt 0.2
  修订版:
  1
  目录
  1 简介
  2 使用SendPkt的流程
  3 SendPkt发送数据包的简单例子
  4 SendPkt发送ARP查询包的例子
  5 参考
  1 简介
  摘自 SendPkt 项目wiki。
  SendPkt是一套同时可以运行在Linux/Win32的发送链路层数据包的Python扩展库。
  SendPkt在Linux和Win32下实现方式是不同的,但是提供对Python的相同接口,确保Python程序可以不经过修改就可以移植。
  在Win32下SendPkt使用WinPcap?中的 pcap_sendpacket() 函数发送数据包。
  在Linux下SendPkt使用libnet的 libnet_adv_write_link() 函数发送数据包。
  同时SendPkt还提供了查找网络接口设备的功能,以供发送数据包时选择。在Linux下虽然可以使用libnet自动选择的网络接口设备,但是在Win32下,默认的网络设备总会导致发包失败。所以为了可移植性,你必须在发送数据包时指定使用哪个网络设备接口。
  2 使用SendPkt的流程
  选择合适的网络接口以发送数据包,因为Win32于Linux的不同,需要专门选择。
  对于Win32,通过libpcap取得的第一个网络设备接口(网卡)是一个虚拟网卡,无法发送数据包,而一般选择第二个网口,可以通过os.name判断操作系统并选择合适的网口。
  得到的网络设备接口列表,是一个字符串列表,最终提供给发送函数的网口标志也是字符串。
  构造数据包。推荐使用dpkt。
  dpkt是python界通用的数据包组包和解包库,在分层构造数据包时从高层(应用层)向底层依次构造数据包。并且把高层数据包的数据作为下一层数据包的data字段来使用。
  对于高性能应用,手工构造数据包也未尝不可,因为哪种方式都需要对数据包格式的深入了解。
  发送数据包,使用 sendpkt.sendpacket() 。
  例子见下面的代码。调用方式为 sendpkt.sendpacket(packet,device) 。第一个参数为数据包,为字符串对象,以太网帧。第二个参数为网络设备名,通过第一步获得。
  3 SendPkt发送数据包的简单例子
  参见SendPkt项目的单元测试 test.py 。:
  import sendpkt
  #构造一个需要发送的数据包
  packet=”a”*80
  #查找所有可用网络设备接口
  devlist=sendpkt.findalldevs()
  #根据操作系统选择合适的网络设备
  if devlist:
  if os.name==”nt”:
  device=devlist[-1] #\\NPF\\….
  elif os.name==”posix”:
  device=devlist #eth0
  else:
  device=devlist
  else:
  device=”"
  raise OSError,”You must run in root mode”
  #发送数据包
  sendpkt.sendpacket(packet,device)
页: [1]
查看完整版本: SendPkt快速入门[Python]