Python之NMAP详解

NMap,也就是Network Mapper,最早是Linux下的网络扫描和嗅探工具包。

nmap是一个网络连接端扫描软件,用来扫描网上电脑开放的网络连接端。确定哪些服务运行在哪些连接端,并且推断计算机运行哪个操作系统(这是亦称 fingerprinting)。它是网络管理员必用的软件之一,以及用以评估网络系统安全。

正如大多数被用于网络安全的工具,nmap 也是不少黑客及骇客(又称脚本小子)爱用的工具 。系统管理员可以利用nmap来探测工作环境中未经批准使用的服务器,但是黑客会利用nmap来搜集目标电脑的网络设定,从而计划攻击的方法。

Nmap 常被跟评估系统漏洞软件Nessus 混为一谈。Nmap 以隐秘的手法,避开闯入检测系统的监视,并尽可能不影响目标系统的日常操作。

Nmap 在黑客帝国(The Matrix)中,连同SSH1的32位元循环冗余校验漏洞,被崔妮蒂用以入侵发电站的能源管理系统。

基本功能有三个,一是探测一组主机是否在线;其次是扫描 主机端口,嗅探所提供的网络服务;还可以推断主机所用的操作系统 。Nmap可用于扫描仅有两个节点的LAN,直至500个节点以上的网络。Nmap 还允许用户定制扫描技巧。通常,一个简单的使用ICMP协议的ping操作可以满足一般需求;也可以深入探测UDP或者TCP端口,直至主机所 使用的操作系统;还可以将所有探测结果记录到各种格式的日志中, 供进一步分析操作。

进行ping扫描,打印出对扫描做出响应的主机,不做进一步测试(如端口扫描或者操作系统探测):

nmap -sP 192.168.1.0/24
仅列出指定网络上的每台主机,不发送任何报文到目标主机:

nmap -sL 192.168.1.0/24
探测目标主机开放的端口,可以指定一个以逗号分隔的端口列表(如-PS22,23,25,80):

nmap -PS 192.168.1.234
使用UDP ping探测主机:

nmap -PU 192.168.1.0/24
使用频率最高的扫描选项:SYN扫描,又称为半开放扫描,它不打开一个完全的TCP连接,执行得很快:

nmap -sS 192.168.1.0/24
本文以linux Ubuntu16.04为例,最后主要用python操作

1. 先安装nmap

sudo apt-get install nmap
2.再安装python-nmap

sudo pip3.6 install python-nmap
安装完之后python导入nmap测试验证是否成功

➜  ~ python3.6
Python 3.6.4 (v3.6.4:d48ecebad5, Dec 18 2017, 21:07:28)
[GCC 4.2.1 (Apple Inc. build 5666) (dot 3)] on darwin
Type "help", "copyright", "credits" or "license" for more information.

>>>
>>>
>>>
>>> import nmap

创建PortScanner实例,然后扫描159.239.210.26这个IP的20-443端口。

import nmap

nm = nmap.PortScanner()
ret = nm.scan('115.239.210.26','20')
print (ret)

返回格式如下:
{'nmap': {'scanstats':
{'uphosts': '1', 'timestr': 'Tue Oct 25 11:30:47 2016', 'downhosts': '0', 'totalhosts': '1', 'elapsed': '1.11'},
 'scaninfo': {'tcp': {'services': '20', 'method': 'connect'}}, 'command_line': 'nmap -oX - -p 20 -sV 115.239.210.26'},
 'scan': {'115.239.210.26': {'status': {'state': 'up', 'reason': 'syn-ack'}, 'hostnames': [{'type': '', 'name': ''}],
 'vendor': {}, 'addresses': {'ipv4': '115.239.210.26'},
 'tcp': {20: {'product': '', 'state': 'filtered', 'version': '', 'name': 'ftp-data', 'conf': '3', 'extrainfo': '',
'reason': 'no-response', 'cpe': ''}
}
}
}
}

内置方法

import nmap
nm = nmap.PortScanner()
print (nm.scaninfo())
{u'tcp': {'services': u'20-443', 'method': u'syn'}}
print (nm.command_line())
u'nmap -oX - -p 20-443 -sV 115.239.210.26'

查看有多少个host

print (nm.all_hosts())
[u'115.239.210.26']
查看该host的详细信息

nm['115.239.210.26']
查看该host包含的所有协议

nm['115.239.210.26'].all_protocols()
查看该host的哪些端口提供了tcp协议

nm['115.239.210.26']['tcp']

nm['115.239.210.26']['tcp'].keys()
查看该端口是否提供了tcp协议

nm['115.239.210.26'].has_tcp(21)
还可以像这样设置nmap执行的参数

nm.scan(hosts='192.168.1.0/24', arguments='-n -sP -PE -PA21,23,80,3389')

定义函数库mytools.py

#-*- coding:utf-8 -*-
import smtplib
from email.mime.text import MIMEText
from email.header import Header
def sendemail(sender,receiver,subject,content,smtpserver,smtpuser,smtppass):
    msg = MIMEText(content,'html','utf-8')#中文需参数'utf-8',单字节字符不需要
    msg['Subject'] = Header(subject, 'utf-8')
    msg['From'] = '' % sender
    msg['To'] = ";".join(receiver)
    try:
        smtp = smtplib.SMTP()
        smtp.connect(smtpserver)
        smtp.login(smtpuser, smtppass)
        smtp.sendmail(sender, receiver, msg.as_string())
        smtp.quit()
    except Exception,e:
        print (e)

实现端口扫描的程序,单线程版本nmscan.py

!/usr/bin/python
-*- coding:utf-8 -*-

import nmap
import re
import mytools as tool
import sys

reload(sys)
sys.setdefaultencoding('utf8')

def nmScan(hostlist, portrange, whitelist):
    p = re.compile("^(\d*)\-(\d*)$")

    if type(hostlist) != list:
        help()
    portmatch = re.match(p, portrange)
    if not portmatch:
        help()
    l = []
    for host in hostlist:
        result = ''
    nm = nmap.PortScanner()
    tmp = nm.scan(host, portrange)
    result = result + "<h2>ip&#x5730;&#x5740;:%s &#x4E3B;&#x673A;&#x540D;:[%s]  ......  %s</h2><hr>" % (
    host, tmp['scan'][host]['hostname'], tmp['scan'][host]['status']['state'])
    try:
        ports = tmp['scan'][host]['tcp'].keys()
    except KeyError, e:
        if whitelist:
            whitestr = ','.join(whitelist)
            result = result + "&#x672A;&#x626B;&#x5230;&#x5F00;&#x653E;&#x7AEF;&#x53E3;!&#x8BF7;&#x68C0;&#x67E5;%s&#x7AEF;&#x53E3;&#x5BF9;&#x5E94;&#x7684;&#x670D;&#x52A1;&#x72B6;&#x6001;" % whitestr
        else:
            result = result + "&#x626B;&#x63CF;&#x7ED3;&#x679C;&#x6B63;&#x5E38;&#xFF0C;&#x65E0;&#x66B4;&#x6F0F;&#x7AEF;&#x53E3;"
    for port in ports:
        info = ''
        if port not in whitelist:
            info = '<strong><font color="red">Alert:&#x975E;&#x9884;&#x671F;&#x7AEF;&#x53E3;</font><strong>&#xA0;&#xA0;'
        else:
            info = '<strong><font color="green">Info:&#x6B63;&#x5E38;&#x5F00;&#x653E;&#x7AEF;&#x53E3;</font><strong>&#xA0;&#xA0;'
        portinfo = "%s <strong>port</strong> : %s &#xA0;&#xA0;<strong>state</strong> : %s &#xA0;&#xA0;<strong>product<strong> : %s <br>" % (
        info, port, tmp['scan'][host]['tcp'][port]['state'],
        tmp['scan'][host]['tcp'][port]['product'])
        result = result + portinfo
    l.append([host, str(result)])
    return l

def help():
    print ("Usage: nmScan(['127.0.0.1',],'0-65535')")

if __name__ == "__main__":
    hostlist = ['10.10.10.10', '10.10.10.11']
    portrange = '0-65535'
    whitelist = [80, 443]
    l = nmScan(hostlist, portrange, whitelist)
    sender = '995345781@qq.com'
    receiver = ['zhangyanlin8851@163.com', '877986976@qq.com']
    subject = '&#x670D;&#x52A1;&#x5668;&#x7AEF;&#x53E3;&#x626B;&#x63CF;'
    smtpserver = 'smtp.exmail.qq.com'
    smtpuser = 'zhangyanlin8851@163.cn'
    smtppass = 'linuxidc163'
    mailcontent = ''
    for i in range(len(l)):
        mailcontent = mailcontent + l[i][1]
    tool.sendemail(sender, receiver, subject, mailcontent, smtpserver, smtpuser, smtppass)
</strong></strong></strong></strong></strong></strong>

多线程版本

!/usr/bin/python
-*- coding:utf-8 -*-

import nmap
import re
import mytools as tool
import sys
from multiprocessing import Pool
from functools import partial

reload(sys)
sys.setdefaultencoding('utf8')

def nmScan(host, portrange, whitelist):
    p = re.compile("^(\d*)\-(\d*)$")
    # if type(hostlist) != list:
    #    help()
    portmatch = re.match(p, portrange)
    if not portmatch:
        help()

    if host == '121.42.32.172':
        whitelist = [25, ]
    result = ''
    nm = nmap.PortScanner()
    tmp = nm.scan(host, portrange)
    result = result + "<h2>ip&#x5730;&#x5740;:%s &#x4E3B;&#x673A;&#x540D;:[%s]  ......  %s</h2><hr>" % (
    host, tmp['scan'][host]['hostname'], tmp['scan'][host]['status']['state'])
    try:
        ports = tmp['scan'][host]['tcp'].keys()
        for port in ports:
            info = ''
            if port not in whitelist:
                info = '<strong><font color="red">Alert:&#x975E;&#x9884;&#x671F;&#x7AEF;&#x53E3;</font><strong>&#xA0;&#xA0;'
            else:
                info = '<strong><font color="green">Info:&#x6B63;&#x5E38;&#x5F00;&#x653E;&#x7AEF;&#x53E3;</font><strong>&#xA0;&#xA0;'
            portinfo = "%s <strong>port</strong> : %s &#xA0;&#xA0;<strong>state</strong> : %s &#xA0;&#xA0;<strong>product<strong> : %s <br>" % (
            info, port, tmp['scan'][host]['tcp'][port]['state'], tmp['scan'][host]['tcp'][port]['product'])
            result = result + portinfo
    except KeyError, e:
        if whitelist:
            whitestr = ','.join(whitelist)
            result = result + "&#x672A;&#x626B;&#x5230;&#x5F00;&#x653E;&#x7AEF;&#x53E3;!&#x8BF7;&#x68C0;&#x67E5;%s&#x7AEF;&#x53E3;&#x5BF9;&#x5E94;&#x7684;&#x670D;&#x52A1;&#x72B6;&#x6001;" % whitestr
        else:
            result = result + "&#x626B;&#x63CF;&#x7ED3;&#x679C;&#x6B63;&#x5E38;&#xFF0C;&#x65E0;&#x66B4;&#x6F0F;&#x7AEF;&#x53E3;"
    return result

def help():
    print &#xFF08;"Usage: nmScan(['127.0.0.1',],'0-65535')"&#xFF09;
    return None

if __name__ == "__main__":
    hostlist = ['10.10.10.10', '10.10.10.11']
    portrange = '0-65535'
    whitelist = [80, 443]
    l = nmScan(hostlist, portrange, whitelist)
    sender = '75501664@qq.com'
    receiver = ['zhangyanlin8851@163.com', '877986976@qq.com']
    subject = '&#x670D;&#x52A1;&#x5668;&#x7AEF;&#x53E3;&#x626B;&#x63CF;'
    smtpserver = 'smtp.exmail.qq.com'
    smtpuser = 'zhangyanlin8851@163.cn'
    smtppass = 'linuxidc163'
    mailcontent = ''
    for i in range(len(l)):
        mailcontent = mailcontent + l[i][1]
    tool.sendemail(sender, receiver, subject, mailcontent, smtpserver, smtpuser, smtppass)
</strong></strong></strong></strong></strong></strong>

Original: https://www.cnblogs.com/baishuchao/p/9338531.html
Author: baishuchao
Title: Python之NMAP详解

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/684786/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • elasticsearch

    一、什么是Elasticsearch? Lucene是一套用于 全文检索和 搜寻的 开源程序库,由Apache软件基金会支持和提供 Lucene提供了一个简单却强大的应用程序接口(…

    技术杂谈 2023年7月10日
    049
  • 《一步到位玩透Ansible》专栏章节目录

    现在这个专栏的内容已经请求下架,所有内容完全免费发布在我的博客中:https://www.junmajinlong.com/ansible/index/。 Original: ht…

    技术杂谈 2023年5月31日
    0100
  • 基于jsp+servlet的银行信贷管理系统。

    运行环境,jdk1.8或者jdk1.7、tomcat8或者tomcat8.5、mysql5.7、eclipse、myeclipse开发环境。 1、🐧1748741328,基于jsp…

    技术杂谈 2023年5月31日
    098
  • 微信天气预报小程序实战开发

    404. 抱歉,您访问的资源不存在。 可能是网址有误,或者对应的内容被删除,或者处于私有状态。 代码改变世界,联系邮箱 contact@cnblogs.com 园子的商业化努力-困…

    2023年5月31日
    0122
  • 设计模式-代理模式

    概念:二十三种设计模式中的一种,属于结构型模式。它的作用就是通过提供一个代理类,让我们在调用目标 方法的时候,不再是直接对目标方法进行调用,而是通过代理类 间接调用。让不属于目标方…

    技术杂谈 2023年7月11日
    082
  • Java复习,Java知识点以及Java面试题(二)

    面向对象:封装,继承,多态 类:相关属性和行为的集合。 对象:该类的具体体现 成员变量和局部变量的区别: 位置:成员变量在类中方法外;局部变量在方法定义中或者方法声明上。 内存中的…

    技术杂谈 2023年6月21日
    077
  • FeatureElevationExpression和FeatureElevationExpressionInfo

    FeatureElevationExpression和FeatureElevationExpressionInfo设置三维 Original: https://www.cnblog…

    技术杂谈 2023年5月30日
    093
  • Golang:手撸一个支持六个级别的日志库

    Golang标准日志库提供的日志输出方法有Print、Fatal、Panic等,没有常见的Debug、Info、Error等日志级别,用起来不太顺手。这篇文章就来手撸一个自己的日志…

    技术杂谈 2023年7月11日
    083
  • 通过js实现整屏滑动+全屏翻页+动画展示+线性图

    demo是模拟的一家教育机构的首页,当时学习的时候写的,主要实现的是整屏滑动,全屏翻页的效果,每次翻页都有动画的效果,内容嵌入了线性图和柱形图,代码实现稍微复杂,纯js实现的,如果…

    技术杂谈 2023年5月31日
    077
  • mac 文本处理命令分享

    2 awk awk ‘{pattern + action}’ {filenames} awk是在每行处理文本的时候,默认按照空格隔离每一个域,对每一个域做处理。也可以直接通过在aw…

    技术杂谈 2023年7月24日
    0124
  • 技术管理进阶——你了解成长的全貌吗?

    原创不易,求分享、求一键三连 周末被 早早聊拉过去做了一次 关于成长的分享,这里将PPT分享出来跟大家交流。 关注公众号,回复成长获取PDF 成长是什么 首先,今天的话题是关于成长…

    技术杂谈 2023年6月1日
    093
  • Docker-dockerfile

    Docker-通过Dockerfile创建镜像 1.Dockerfile简介 简而言之,Dockerfile 是一个描述如何创建 Docker 镜像所需步骤的文本文件。 一个Doc…

    技术杂谈 2023年7月10日
    081
  • Mybatis源码1JDBC->mybatis主要流程->mybatis Excutor简介

    === 一丶mybatis概述 MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获…

    技术杂谈 2023年7月25日
    078
  • Promise.all、race和any方法都是什么意思?

    这篇文章发布于 2021年05月9日,星期日,22:51,归类于 JS API。 阅读 11154 次, 今日 1 次 9 条评论 by zhangxinxu from https…

    技术杂谈 2023年6月1日
    082
  • “数据科学”面临的若干问题

    一、”数据科学”研究的对象是什么? 计算机科学是关于算法的科学,数据科学是关于数据的科学。从事数据科学研究的学者更关注数据的科学价值,试图把数据当成一个&#…

    技术杂谈 2023年7月24日
    067
  • 安卓逆向从0到1学习总结

    PS:该文已经首发于公众号信安之路!!! 初识安卓逆向是在2019年的暑假,到现在也快一年了,这一年来有刚从web渗透转来的迷茫,有成功破解了第一个app的喜悦,也有通宵熬夜逆向的…

    技术杂谈 2023年7月11日
    082
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球