Python 端口扫描(全连接扫描,多线程)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python 端口扫描(全连接扫描,多线程)相关的知识,希望对你有一定的参考价值。

from socket import *
import threading      #导入线程相关模块

lock = threading.Lock()
openNum = 0
threads = []              #定义线程列表

def portScanner(host,port):
    global openNum
    try:
        s = socket(AF_INET,SOCK_STREAM)
        s.connect((host,port))
        lock.acquire()        #因为openNum是个全局变量,每个线程不能对openNum 同时操作,只有获得所的线程才可以操作 openNum
        openNum+=1
        print(‘[+] %d open‘ % port)
        lock.release()        #线程对全局变量openNum操作完成后,需要释放所,其他线程才可以继续修改全局变量openNum
        s.close()
    except:                     #如果端口没开,那么就直接pass,不执行其他输出操作。
        pass

def main():
    setdefaulttimeout(1)
    ports = [20, 21, 22, 23, 80, 111, 3306]     #定义要扫描的端口,也可以在for中使用range进行定义,看个人需求,例如 for p in range(1,1024): 
    for p in ports:
        t = threading.Thread(target=portScanner,args=(‘192.168.60.130‘,p))
        threads.append(t)
        t.start()

    for t in threads:        #等待线程列表中的所以线程的执行完毕
        t.join()

    print(‘[*] The scan is complete!‘)
    print(‘[*] A total of %d open port‘ % (openNum))

if __name__ == ‘__main__‘:
    main()

如果要计算扫描了多久的话,可以导入time模块,然后 程序开始运行的时间 减去 程序结束运行的时间 最后输出时间的差。

以上是关于Python 端口扫描(全连接扫描,多线程)的主要内容,如果未能解决你的问题,请参考以下文章

TCP端口扫描类型-隐蔽扫描和僵尸扫描

Python3实现TCP端口扫描

python端口扫描用多线程+线程安全的队列+Thread类实现

python 简单的多线程端口扫描仪

python高性能代码之多线程优化

工具开发——端口开放扫描