Python实现端口检测

发布时间:2019-09-21 11:10:07编辑:auto阅读(1443)

    一、背景:

    在平时工作中有遇到端口检测,查看服务端特定端口是否对外开放,常用nmap,tcping,telnet等,同时也可以利用站长工具等web扫描端口等。
    但是在使用站长工具发现:

    • 每次只能输入一个检测的地址;
    • 虽然可以输入多个端口,但是不能指定一个端口范围来进行批量检测;
    • 没有批量任务记录日志等;
      Python实现端口检测

    因避免由于局域网检测发起端网络限制而导致的端口检测异常,未使用python-nmap
    想通过调用站长工具,实现

    • 单次可多个地址或域名检测
    • 单次可指定端口范围,批量检测
    • 记录日志

    二、代码:

    2.1 结构

    Python实现端口检测

    2.2 代码

    github地址
    部分代码

    #配置文件
    #端口检测配置
    [port_check_info]
    
    #检测ip地址或域名
    #address = baidu.com
    #address = 127.0.0.1
    address = www.anchnet.com,www.51cto.com,www.baidu.com
    
    #检查的端口,如多个端口使用,隔开,端口范围使用'-'
    #ports = 80,8080....
    ports = 20-25,80,443,1433,1521,3306,3389,6379,8080,27017
    
    #日志配置
    [loginfo]
    #日志目录
    logdir_name = logdir
    
    #日志文件名称
    logfile_name = check_port.log
    
       def _get_body(self):
            """
            获取address和port
            :return: list
            """
            address_list = self.address_list.split(',')
            port_list = self.port_list.split(',')
    
            # 处理端口范围,返回range
            range_flag = False
            port_range = None
            content_List_range = []
            for port in port_list:
                if '-' in port:
                    range_flag = True
                    port_range = range(int(port.split('-')[0]),int(port.split('-')[1])+1)
                    port_list.remove(port)
    
            # 处理总体list
            for add in address_list:
                if range_flag:
                    for port in port_range:
                        content_List_range.append(add + ':' + str(port))
    
            # 合并range和普通list
            content_List = [ add+':'+port for add in address_list for port in port_list ]
            content_List_range.extend(content_List)
            return content_List_range
    
        def run(self):
            """
            进行端口检测
            :return:
            """
            for content in self._get_body():
                content_list = content.split(':')
                body = {
                    'host': content_list[0],
                    'port': content_list[1],
                    'encode': 'tlCHS1u3IgF4sC57m6KOP3Oaj1Y1kfLq'
                }
                try:
                    response = requests.post(url=self.url,data=body,headers=self.headers)
                    port_status = re.findall("msg:'(.*?)'", response.text)
                    if len(port_status) > 0:
                        # print('%s,port status is:%s' % (content, port_status))
                        self.logoper.info('%s,port status is:%s' % (content, port_status))
                    else:
                        self.logoper.info('%s,port status is:%s' % (content, port_status))
                        # print('Occer error!请输入正确的地址和端口')
                except Exception as e:
                    print(e)
    

    三、测试:

    3.1 查看检测结果

    Python实现端口检测
    此处可以查看51cto的8080端口也是开放的。

    3.2 查看日志

    Python实现端口检测

    四、改进:

    • 后期可以添加异步多进程等来提升效率
    • 可以对比多个站点检测结果,使结果更准确
    • 整合nmap内网也可检测

关键字