Python实现端口检测

举报
技术火炬手 发表于 2018/07/24 10:52:14 2018/07/24
【摘要】 一、背景:在平时工作中有遇到端口检测,查看服务端特定端口是否对外开放,常用nmap,tcping,telnet等,同时也可以利用站长工具等web扫描端口等。但是在使用站长工具发现:每次只能输入一个检测的地址;虽然可以输入多个端口,但是不能指定一个端口范围来进行批量检测;没有批量任务记录日志等;因避免由于局域网检测发起端网络限制而导致的端口检测异常,未使用python-nmap想通过调用站长工...

一、背景:

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

  • 每次只能输入一个检测的地址;

  • 虽然可以输入多个端口,但是不能指定一个端口范围来进行批量检测;

  • 没有批量任务记录日志等;
    Python实现端口检测

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

  • 单次可多个地址或域名检测

  • 单词可指定端口范围,批量检测

  • 记录日志

二、代码:

2.1 结构

Python实现端口检测

2.2 代码

github地址
部分代码

#配置文件#端口检测配置[port_check_info]#检测ip地址或域名#address = baidu.com#address = 127.0.0.1address = 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内网也可检测


本文转自KaliArch博客51CTO博客,如需转载,请自行联系原作者。

原文链接


【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。