Python实现端口检测
【摘要】 一、背景:在平时工作中有遇到端口检测,查看服务端特定端口是否对外开放,常用nmap,tcping,telnet等,同时也可以利用站长工具等web扫描端口等。但是在使用站长工具发现:每次只能输入一个检测的地址;虽然可以输入多个端口,但是不能指定一个端口范围来进行批量检测;没有批量任务记录日志等;因避免由于局域网检测发起端网络限制而导致的端口检测异常,未使用python-nmap想通过调用站长工...
一、背景:
在平时工作中有遇到端口检测,查看服务端特定端口是否对外开放,常用nmap,tcping,telnet等,同时也可以利用站长工具等web扫描端口等。
但是在使用站长工具发现:
每次只能输入一个检测的地址;
虽然可以输入多个端口,但是不能指定一个端口范围来进行批量检测;
没有批量任务记录日志等;
因避免由于局域网检测发起端网络限制而导致的端口检测异常,未使用python-nmap
想通过调用站长工具,实现
单次可多个地址或域名检测
单词可指定端口范围,批量检测
记录日志
二、代码:
2.1 结构
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 查看检测结果
此处可以查看51cto的8080端口也是开放的。
3.2 查看日志
四、改进:
后期可以添加异步多进程等来提升效率
可以对比多个站点检测结果,使结果更准确
整合nmap内网也可检测
本文转自KaliArch博客51CTO博客,如需转载,请自行联系原作者。
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)