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文件比较示例分享
Jan 10 Python
Python实现竖排打印传单手机号码易撕条
Mar 16 Python
Python读取网页内容的方法
Jul 30 Python
Python中的id()函数指的什么
Oct 17 Python
python向已存在的excel中新增表,不覆盖原数据的实例
May 02 Python
python语音识别实践之百度语音API
Aug 30 Python
对python中的try、except、finally 执行顺序详解
Feb 18 Python
Django使用消息提示简单的弹出个对话框实例
Nov 15 Python
pycharm 设置项目的根目录教程
Feb 12 Python
python词云库wordcloud的使用方法与实例详解
Feb 17 Python
python爬虫beautifulsoup解析html方法
Dec 07 Python
python 使用openpyxl读取excel数据
Feb 18 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下实现在指定目录搜索指定类型文件的函数
2008/10/03 PHP
php求两个目录的相对路径示例(php获取相对路径)
2014/03/27 PHP
dedecms函数分享之获取某一栏目所有子栏目
2014/05/19 PHP
thinkphp常见路径用法分析
2014/12/02 PHP
兼容FireFox 的 js 日历 支持时间的获取
2009/03/04 Javascript
javascript URL编码和解码使用说明
2010/04/12 Javascript
javascript针对DOM的应用分析(二)
2012/04/15 Javascript
深入document.write()与HTML4.01的非成对标签的详解
2013/05/08 Javascript
jquery 页面滚动到指定DIV实现代码
2013/09/25 Javascript
深入理解JavaScript系列(46):代码复用模式(推荐篇)详解
2015/03/04 Javascript
javascript函数自动执行常用方法汇总
2016/03/28 Javascript
Javascript 调用 ActionScript 的简单方法
2016/09/22 Javascript
学习JavaScript图片预加载模块
2016/11/07 Javascript
使用AngularJS 跨站请求如何解决jsonp请求问题
2017/01/16 Javascript
浅析webpack 如何优雅的使用tree-shaking(摇树优化)
2017/08/16 Javascript
bootstrap switch开关组件使用方法详解
2017/08/22 Javascript
jQuery+PHP实现上传裁剪图片
2020/06/29 jQuery
微信小程序实现pdf、word等格式文件上传的方法
2019/09/10 Javascript
ES6中的类(Class)示例详解
2020/12/09 Javascript
[01:31:02]TNC vs VG 2019国际邀请赛淘汰赛 胜者组赛BO3 第一场
2019/08/22 DOTA
python实现红包裂变算法
2016/02/16 Python
一行代码让 Python 的运行速度提高100倍
2018/10/08 Python
详解Python二维数组与三维数组切片的方法
2019/07/18 Python
python实现桌面托盘气泡提示
2019/07/29 Python
django重新生成数据库中的某张表方法
2019/08/28 Python
用python的turtle模块实现给女票画个小心心
2019/11/23 Python
浅析Python3 pip换源问题
2020/01/06 Python
pytorch 模拟关系拟合——回归实例
2020/01/14 Python
Python爬虫:Request Payload和Form Data的简单区别说明
2020/04/30 Python
HTML5微信播放全屏问题的解决方法
2017/03/09 HTML / CSS
德国最大的网上鞋店之一:Schuhe24.de
2017/06/10 全球购物
PUMA澳大利亚官方网站:德国运动品牌
2018/10/19 全球购物
澳大利亚100%丝绸多彩度假装商店:TheSwankStore
2019/09/04 全球购物
企业管理专业个人求职信范文
2013/09/24 职场文书
医院深入开展党的群众路线教育实践活动实施方案
2014/08/27 职场文书
大学生奖学金获奖感言(范文)
2019/08/15 职场文书