1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
|
import pcs
from pcs import *
from pcs.packets.arp import *
from pcs.packets.ethernet import *
def main():
from optparse import OptionParser
parser = OptionParser()
parser.add_option("-i", "--interface",
dest="interface", default=None,
help="Network interface to send on.")
parser.add_option("-t", "--target",
dest="target", default=None,
help="IPv4 target address to lookup.")
parser.add_option("-e", "--ether_source",
dest="ether_source", default=None,
help="Ethernet source address to use.")
parser.add_option("-p", "--ip_source",
dest="ip_source", default=None,
help="IPv4 source address to use.")
(options, args) = parser.parse_args()
arppkt = arp()
arppkt.op = 1
arppkt.sha = ether_atob(options.ether_source)
arppkt.spa = inet_atol(options.ip_source)
arppkt.tha = "\x00\x00\x00\00\x00\x00"
arppkt.tpa = inet_atol(options.target)
ether = ethernet()
ether.src = ether_atob(options.ether_source)
ether.dst = "\xff\xff\xff\xff\xff\xff"
ether.type = 0x806
packet = Chain([ether, arppkt])
output = PcapConnector(options.interface)
out = output.write(packet.bytes, len(packet.bytes))
reply = output.read()
reply = output.read()
packet = ethernet(reply)
print packet
print packet.data
main()
|