python3扫描_详解python3之实现高效的端口扫描

python3实现高效的端口扫描

我们通过python-nmap实现一个高效的端口扫描工具,与定时作业crontab及邮件告警结合,可以很好的帮助我们及时发现异常开放的高危端口。当然,该工具也可以作为业务服务端口的可用性探测,例如扫描192.168.209.121-125网段Web服务端口80s是否处于open状态。我们这里所采用的scan方法arguments参数指定为-v -PE -p + 端口, -v表示启用细节模式,可以返回非up状态主机清单;-PE表示采用TCP同步扫描(TCP SYN)方式; -p指定扫描端口范围。程序输出部分采用三个for循环体,第一层遍历扫描主机,第二层为遍历协议,第三层为遍历端口,最后输出主机状态。

具体脚本port_scanner.py代码如下:

import sys

import nmap

scan_row = []

input_data = input('Please input hosts and port: ')

#scan_row以空格分隔

scan_row = input_data.split(' ')

if len(scan_row) != 2:

print("Input errors, example \"192.168.209.0/24 80,443,22 \"")

sys.exit(0)

#接收用户输入的主机

hosts = scan_row[0]

#接收用户收入的端口

port = scan_row[1]

try:

#创建端口扫描对象

nm = nmap.PortScanner()

except nmap.PortScannerError:

print('Nmap not found', sys.exc_info()[0])

sys.exit(0)

except Exception as e:

print("Unexpected error:", sys.exc_info()[0])

print(str(e))

sys.exit(0)

try:

#调用扫描方法,参数指定扫描主机hosts,nmap扫描命令行参数arguments

nm.scan(hosts=hosts, arguments=' -v -sS -p ' + port)

except Exception as e:

print("Scan error:" + str(e))

for host in nm.all_hosts():

print('---------------------------------------------------------------------')

#输出主机及主机名

print('Host : %s (%s)' % (host, nm[host].hostname()))

#输出主机状态,如up、down

print('State : %s' % nm[host].state())

#遍历扫描协议,tcp、udp

for proto in nm[host].all_protocols():

print('--------------')

#输出协议名

print('Protocol : %s' % proto)

#获取协议的所有扫描端口

lport = list(nm[host][proto].keys())

#端口列表排序

lport.sort()

#遍历端口输出端口与状态

for port in lport:

print('port %s\tstate : %s' % (port, nm[host][proto][port]['state']))

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持码农之家。

以上就是本次给大家分享的关于java的全部知识点内容总结,大家还可以在下方相关文章里找到相关文章进一步学习,感谢大家的阅读和支持。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值