python多线程端口扫描程序

下面的程序给出了对给定的ip主机进行多线程扫描的python代码

#!/usr/bin/env python
#encoding: utf-8

import socket, sys, thread, time

openPortNum = 0
socket.setdefaulttimeout(3)

def usage():
    print '''Usage:
    Scan the port of one IP: python port_scan_multithread.py -o <ip>
    Scan the port of one IP: python port_scan_multithread.py -m <ip1, ip2, ip3, ip4 ...>
    '''
    print 'Exit'
    sys.exit(1)

def socket_port(ip, PORT):
    global openPortNum
    if PORT > 65535:
        print 'Port scanning beyond the port range, interrupt to scan'
        sys.exit(1)
    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    result = s.connect_ex((ip, PORT))
    if(result == 0):
        print ip, PORT,'is open'
        openPortNum += 1
    s.close()

def start_scan(IP):
    for port in range(0, 65535+1):
        thread.start_new_thread(socket_port, (IP, int(port)))
        time.sleep(0.006)

if __name__ == '__main__':
    t = 0
    if len(sys.argv)<2 or sys.argv[1] == '-h':
        usage()
    elif sys.argv[1] == '-o':
        ONE_IP = raw_input('Please input ip of scanning: ')
        t = time.time()
        start_scan(ONE_IP)
    elif sys.argv[1] == '-m':
        MANY_IP = raw_input('Please input many ip of scanning: ')
        IP_SEG = MANY_IP.split(',')
        t = time.time()
        for i in IP_SEG:
            start_scan(i)

    print
    print 'total open port is %s, scan used time is: %f ' % (openPortNum, time.time()-t)

运行效果图


参考文献

[1].http://moniter.blog.51cto.com/2908666/1355004

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python 中可以通过多线程实现端口扫描,实现快速扫描目标主机上哪些端口是开放状态的,从而可以进一步确认主机的安全状况。 多线端口扫描原理是:主线程开启多个子线程执行端口扫描任务,每个子线程单独扫描一部分端口,将结果存储到共享变量中,主线程最后将这些结果合并并输出。 下面是一个基本的 Python线端口扫描程序: ```python import threading import socket target = '127.0.0.1' # 目标主机 start_port = 1 # 扫描的起始端口 end_port = 100 # 扫描的终止端口 open_ports = [] # 存放开放端口的列表 def scan(port): s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s.settimeout(0.5) try: s.connect((target, port)) open_ports.append(port) s.close() except: pass def main(): for port in range(start_port, end_port + 1): t = threading.Thread(target=scan, args=(port,)) t.start() for t in threading.enumerate(): if t != threading.current_thread(): t.join() open_ports.sort() for port in open_ports: print(f'Port {port} is open') if __name__ == '__main__': main() ``` 这个程序定义了一个扫描函数 scan(),使用 socket 模块创建 TCP 套接字 s,设置 timeout 时间为 0.5 秒,然后通过 connect() 方法连接目标主机的某个端口,如果连接成功则将端口号添加到 open_ports 列表中。 在主函数中,使用 for 循环创建多个子线程,每个子线程执行一次 scan() 函数来扫描一个端口号。然后通过 threading.enumerate() 方法获取当前所有线程的列表,再使用 join() 方法等待所有子线程完成,最后按端口号从小到大排序,输出所有开放的端口。 需要注意的是,端口扫描是一种比较敏感的操作,因此需要获得目标主机的合法授权后进行,否则可能会对目标主机造成安全风险。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值