Python Scapy實現Ping掃描

#!/usr/bin/python3
# -*- coding: utf-8 -*- 
# --author:valecalida--
from scapy.layers.inet import IP, ICMP, sr1
from random import randint
from ipaddress import ip_network
from threading import Thread
import time


def ping_single(ip):
    ip_id = randint(1, 65535)
    icmp_id = randint(1, 65535)
    icmp_seq = randint(1, 65535)
    packet = IP(dst=ip, ttl=64, id=ip_id)/ICMP(id=icmp_id, seq=icmp_seq)
    response = sr1(packet, timeout=1, verbose=0)
    if response:
        print("[+] %s is alive" % str(ip))


def ping_scan(network):
    ip_list = ip_network(network)
    for ip in ip_list:
        t = Thread(target=ping_single, args=[str(ip)])
        t.start()


if __name__ == '__main__':

    host = '10.87.51.0/24'
    t1 = time.time()
    ping_scan(host)
    t2 = time.time()
    print("[+] 本次掃描共花費 %s 秒" % (t2 - t1))

運行結果:

[+] 10.87.51.1 is alive
[+] 10.87.51.3 is alive
[+] 本次掃描共花費 9.59500789642334 秒

花費時間還是比較長,下一版考慮優化

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章