Python實現端口檢測


一、背景:
在平時工作中有遇到端口檢測,查看服務端特定端口是否對外開放,常用nmap,tcping,telnet等,同時也可以利用站長工具等web掃描端口等。
但是在使用站長工具發現:

每次只能輸入一個檢測的地址;
雖然可以輸入多個端口,但是不能指定一個端口范圍來進行批量檢測;
沒有批量任務記錄日志等;

因避免由於局域網檢測發起端網絡限制而導致的端口檢測異常,未使用python-nmap
想通過調用站長工具,實現

單次可多個地址或域名檢測
單次可指定端口范圍,批量檢測
記錄日志
二、代碼:
2.1 結構


2.2 代碼
github地址

info.cfg代碼

#address = 8.8.8.8
address = www.moguyun.com,www.51cto.com,www.anchnet.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
  • logger.py代碼
  • #!/bin/env python
    # -*- coding:utf-8 -*-
    # _auth:kelly
     
     
    import os
    import time
    import logging
    import configparser
     
    class LogHelper():
        """
        初始化logger,讀取目錄及文件名稱
        """
        def __init__(self):
            configoper = configparser.ConfigParser()
            configoper.read('info.cfg',encoding='utf-8')
            self.logdir_name = configoper['loginfo']['logdir_name']
            self.logfile_name = configoper['loginfo']['logfile_name']
     
        def create_dir(self):
            """
            創建目錄
            :return: 文件名稱
            """
            _LOGDIR = os.path.join(os.path.dirname(__file__), self.logdir_name)
            _TIME = time.strftime('%Y-%m-%d', time.gmtime()) + '-'
            _LOGNAME = _TIME + self.logfile_name
            LOGFILENAME = os.path.join(_LOGDIR, _LOGNAME)
            if not os.path.exists(_LOGDIR):
                os.mkdir(_LOGDIR)
            return LOGFILENAME
     
        def create_logger(self, logfilename):
            """
            創建logger對象
            :param logfilename:
            :return: logger對象
            """
            logger = logging.getLogger()
            logger.setLevel(logging.INFO)
            handler = logging.FileHandler(logfilename)
            handler.setLevel(logging.INFO)
            formater = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
            handler.setFormatter(formater)
            logger.addHandler(handler)
            return logger
    • tcp_check_port.py 代碼
#!/bin/env python
# -*- coding:utf-8 -*-
# _auth:kaliarch
 
import requests
from configparser import ConfigParser
import re
 
from tcp_port_check import logger
 
 
class check_ports():
    def __init__(self,logger):
        """
        初始化,獲取配置文件信息
        """
        self.url = 'http://tool.chinaz.com/iframe.ashx?t=port'
        self.headers = {
            'Accept': 'text/javascript, application/javascript, application/ecmascript, application/x-ecmascript, */*; q=0.01',
            'Accept-Encoding': 'gzip, deflate',
            'Accept-Language': 'zh-CN,zh;q=0.8',
            'Connection': 'keep-alive',
            'Content-Length': '62',
            'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
            'Host': 'tool.chinaz.com',
            'Origin': 'http://tool.chinaz.com',
            'Referer': 'http://tool.chinaz.com/port/',
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 Safari/537.36',
            'X-Requested-With': 'XMLHttpRequest'
        }
        config = ConfigParser()
        config.read('info.cfg',encoding='utf-8')
        self.address_list = config['port_check_info']['address']
        self.port_list = config['port_check_info']['ports']
        #初始化logger
        logger = logger.LogHelper()
        logname = logger.create_dir()
        self.logoper = logger.create_logger(logname)
 
 
    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:
                self.logoper.info(e)
 
 
if __name__ == '__main__':
    check_app = check_ports(logger)
    check_app.run()

 

 

 


————————————————
版權聲明:本文為CSDN博主「李俊的博客」的原創文章,遵循 CC 4.0 BY 版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/qq_36441027/article/details/105628425


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM