Python实现的多线程端口扫描工具分享


Posted in Python onJanuary 21, 2015

昨晚今晚写了两晚,总算把Py Port Scanner 写完了,姑且称之为0.1版本,算是一个Python多线程端口扫描工具。

水平有限,实话中间有一些困惑和不解的地方,代码可能也写的比较乱。有些问题并未找到很好的解决方法,还望大家谅解。速度大家自己试验,我感觉还行。

送上效果图两份,分别是扫单IP和扫IP段:

Python实现的多线程端口扫描工具分享

Python实现的多线程端口扫描工具分享

源码:

# -*- coding: utf-8 -*-

__author__ = 'Phtih0n'

import threading, socket, sys, cmd, os, Queue
#扫描常用端口

PortList = [21, 22, 23, 25, 80, 135, 137, 139, 445, 1433, 1502, 3306, 3389, 8080, 9015]

#得到一个队列

def GetQueue(list):

    PortQueue = Queue.Queue(65535)

    for p in list:

        PortQueue.put(p)

    return PortQueue
#单IP扫描线程个数

nThread = 20

#线程锁

lock = threading.Lock()

#超时时间

Timeout = 3.0

#打开的端口列表

OpenPort = []
class ScanThread(threading.Thread):

    def __init__(self, scanIP):

        threading.Thread.__init__(self)

        self.IP = scanIP
    def Ping(self, Port):

        global OpenPort, lock, Timeout

        sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

        sock.settimeout(Timeout)

        address = (self.IP, Port)

        try:

            sock.connect(address)

        except:

            sock.close()

            return False

        sock.close()

        OpenPort.append(Port)

        if lock.acquire():

            print "IP:%s  Port:%d" % (self.IP, Port)

            lock.release()

        return True


class ScanThreadSingle(ScanThread):

    def __init__(self, scanIP, SingleQueue):

        ScanThread.__init__(self, scanIP)

        self.SingleQueue = SingleQueue
    def run(self):

        while not self.SingleQueue.empty():

            p = self.SingleQueue.get()

            self.Ping(p)


class ScanThreadMulti(ScanThread):

    def __init__(self, scanIP, PortList):

        ScanThread.__init__(self, scanIP)

        self.List = PortList[:]
    def run(self):

        for p in self.List:

            self.Ping(p)
class Shell(cmd.Cmd):

    u'''Py Port Scanner 0.1 使用说明:

    port [port..] 设置扫描的端口,用逗号分隔。

        默认:21, 22, 23, 25, 80, 135, 137, 139, 445, 1433, 1502, 3306, 3389, 8080, 9015

        example:port 21,23,25

        example: port 1000..2000

        example: port 80,443,1000..1500

    scan [IP] 扫描某一IP地址

        example: scan 192.168.1.5

    search [IP begin]-[IP end] 扫描某一IP段

        example: search 192.168.1.1-192.168.1.100

    time [timeout] 设置超时时间,默认为3秒

        example: time 5

    cls 清楚屏幕内容

    listport 打印端口列表

    help 打开本帮助

        '''

    def __init__(self):

        cmd.Cmd.__init__(self)

        reload(sys)

        sys.setdefaultencoding('utf-8')

        self.prompt = "Port Scan >>"

        self.intro = "Py Port Scanner 0.1"
    def do_EOF(self, line):

        return True
    def do_help(self, line):

        print self.__doc__
    #设置端口

    def do_port(self, line):

        global PortList

        PortList = []

        ListTmp = line.split(',')

        for port in ListTmp:

            if port.find("..") < 0:

                if not port.isdigit():

                    print "输入错误"

                    return False

                PortList.append(int(port))

            else:

                RangeLst = port.split("..")

                if not (RangeLst[0].isdigit() and RangeLst[1].isdigit()):

                    raise ValueError

                    exit()

                for i in range(int(RangeLst[0]), int(RangeLst[1])):

                    PortList.append(i)
    def do_scan(self, line):

        global nThread, PortList

        ThreadList = []

        strIP = line

        SingleQueue = GetQueue(PortList)

        for i in range(0, nThread):

            t = ScanThreadSingle(strIP, SingleQueue)

            ThreadList.append(t)

        for t in ThreadList:

            t.start()

        for t in ThreadList:

            t.join()
    def do_search(self, line):

        global nThread, PortList

        ThreadList = []

        (BeginIP, EndIP) = line.split("-")

        try:

            socket.inet_aton(BeginIP)

            socket.inet_aton(EndIP)

        except:

            print "输入错误"

            return

        IPRange = BeginIP[0:BeginIP.rfind('.')]

        begin = BeginIP[BeginIP.rfind('.') + 1:]

        end = EndIP[EndIP.rfind('.') + 1:]

        for i in range(int(begin), int(end)):

            strIP = "%s.%s" % (IPRange, i)

            t = ScanThreadMulti(strIP, PortList)

            ThreadList.append(t)

        for t in ThreadList:

            t.start()

        for t in ThreadList:

            t.join()
    def do_listport(self, line):

        global PortList

        for p in PortList:

            print p,

        print '\n'
    def do_time(self, line):

        global Timeout

        try:

            Timeout = float(line)

        except:

            print u"参数错误"
    def do_cls(self, line):

        os.system("cls")


if '__main__' == __name__:

    try:

        os.system("cls")

        shell = Shell()

        shell.cmdloop()

    except:

        exit()
Python 相关文章推荐
从Python的源码浅要剖析Python的内存管理
Apr 16 Python
Python的净值数据接口调用示例分享
Mar 15 Python
Python基于matplotlib绘制栈式直方图的方法示例
Aug 09 Python
python用户管理系统的实例讲解
Dec 23 Python
python使用TensorFlow进行图像处理的方法
Feb 28 Python
python requests 测试代理ip是否生效
Jul 25 Python
python 抓包保存为pcap文件并解析的实例
Jul 23 Python
python多进程并行代码实例
Sep 30 Python
通俗讲解python 装饰器
Sep 07 Python
浅析pandas随机排列与随机抽样
Jan 22 Python
python3实现Dijkstra算法最短路径的实现
May 12 Python
Python数据可视化之Seaborn的安装及使用
Apr 19 Python
Python中的pprint折腾记
Jan 21 #Python
通过C++学习Python
Jan 20 #Python
python入门之语句(if语句、while语句、for语句)
Jan 19 #Python
Python实现删除Android工程中的冗余字符串
Jan 19 #Python
Python中字典和JSON互转操作实例
Jan 19 #Python
Python中的字典遍历备忘
Jan 17 #Python
Python中处理unchecked未捕获异常实例
Jan 17 #Python
You might like
社区(php&amp;&amp;mysql)六
2006/10/09 PHP
修改PHP的memory_limit限制的方法分享
2012/02/21 PHP
解析func_num_args与func_get_args函数的使用
2013/06/24 PHP
ThinkPHP实现附件上传功能
2017/04/27 PHP
什么是PHP文件?如何打开PHP文件?
2017/06/27 PHP
javascript 混合的构造函数和原型方式,动态原型方式
2009/12/07 Javascript
jquery 简短几句代码实现给元素动态添加及获取提示信息
2011/09/01 Javascript
JS验证控制输入中英文字节长度(input、textarea等)具体实例
2013/06/21 Javascript
详解JavaScript编程中正则表达式的使用
2015/10/25 Javascript
Easyui的组合框的取值与赋值
2016/10/28 Javascript
JavaScript使用正则表达式获取全部分组内容的方法示例
2017/01/17 Javascript
nodejs操作mongodb的增删改查功能实例
2017/11/09 NodeJs
利用ES6实现单例模式及其应用详解
2017/12/09 Javascript
vue axios请求拦截实例代码
2018/03/29 Javascript
JavaScript变量声明var,let.const及区别浅析
2018/04/23 Javascript
vue如何将v-for中的表格导出来
2018/05/07 Javascript
vue单页应用的内存泄露定位和修复问题小结
2019/08/02 Javascript
Vue使用mixin分发组件的可复用功能
2019/09/01 Javascript
layui checkbox默认选中,获取选中值,清空所有选中项的例子
2019/09/02 Javascript
解决layui的radio属性或别的属性没显示出来的问题
2019/09/26 Javascript
[54:51]Ti4 冒泡赛第二轮LGD vs C9 3
2014/07/14 DOTA
python解析文件示例
2014/01/23 Python
讲解Python中if语句的嵌套用法
2015/05/14 Python
详解Python自建logging模块
2018/01/29 Python
解决python中使用plot画图,图不显示的问题
2018/07/04 Python
Python爬虫爬取电影票房数据及图表展示操作示例
2020/03/27 Python
浅谈python锁与死锁问题
2020/08/14 Python
浅谈Html5移动端ios/Android兼容性总结
2018/06/01 HTML / CSS
final, finally, finalize的区别
2012/03/01 面试题
《草原的早晨》教学反思
2014/04/08 职场文书
政治表现评语
2014/05/04 职场文书
作文评语怎么写
2014/12/25 职场文书
英语邀请函范文
2015/02/02 职场文书
总经理岗位职责
2015/02/04 职场文书
数学教师个人总结
2015/02/06 职场文书
地震慰问信
2015/02/14 职场文书