当前位置: 移动技术网 > IT编程>脚本编程>Python > python3实现高效的端口扫描

python3实现高效的端口扫描

2019年09月06日  | 移动技术网IT编程  | 我要评论

努努书坊,文艺句子,军统枪口下的女人剧情介绍

我们通过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']))

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网