Nmap

## 1.nmap功能介绍

* 1.主机存活检测
* 2.端口探测
* 3.服务识别
* 4.操作系统识别
* 5.硬件地址检测
* 6.服务版本识别
* 7.漏洞扫描,使用nmap自带脚本

## 2.简单示例

使用ping检测10.0.0.0/24这个网段

    nmap -sP 10.0.0.0/24

使用SYN的方法对全端口进行扫描,在aggressive(4)的时间模板下,同时对开放的端口进行端口识别
   
    nmap -p1-65535 -sV -sS -T4 target
PS: -T代表的是扫描的时候,一些控制选项(TCP的延迟时间,探测报文之间的间隔等)的集合,具体的man nmap一下就知道了

使用SYN扫描,在aggressive(4)的时间模板下,探测操作系统的类型和版本,还有显示traceroute的结果,结果输出较为详细

    nmap -v-sS -A -T4 target

使用SYN扫描,在insane(5)的时间模板下,探测操作系统的类型和版本,还有显示traceroute的结果,结果输出较为详细

    nmap -v-sS -A -T5 target

使用SYN扫描,在insane(5)的时间模板下,探测操作系统的类型,还有显示traceroute的结果,操作系统的类型,结果输出较为详细

    nmap -v-sV -O -sS -T5 target

使用SYN的方法对全端口进行扫描,同时对开放的端口进行端口识别,在aggressive(4)的时间模板下,探测操作系统的类型还有显示traceroute的结果,结果输出较为详细

    nmap -v-p 1-65535 -sV -O -sS -T4 target

用SYN的方法对全端口进行扫描,同时对开放的端口进行端口识别,在insane(5)的时间模板下,探测操作系统的类型,还有显示traceroute的结果,结果输出较为详细

    nmap -v-p 1-65535 -sV -O -sS -T5 target

从文件中读取需要扫描的IP列表

    nmap -iL ip-address.txt

### Nmap输出格式

扫描的结果输出到屏幕,同时会存储一份到grep-output.txt

nmap -sV -p 139,445 -oG grep-output.txt 10.0.1.0/24

扫描结果输出为html

nmap -sS -sV -T5 10.0.1.99 --webxml -oX - | xsltproc --output file.html

### Nmap扫描Netbios

在子网中发现开放netbios的IP

nmap -sV -v-p139,445 10.0.0.1/24

扫描指定netbios的名称

nmap -sU --script nbstat.nse -p 137 target

扫描指定的目标,同时检测相关漏洞

nmap --script-args=unsafe=1 --script smb-check-vulns.nse -p 445 target

将nmap的80端口的扫描结果,通过管道交给nikto进行扫描

Nmap Nikto Scan nmap -p80 10.0.1.0/24-oG - | nikto.pl -h -

将nmap的80,443端口的扫描结果,通过管道交给nikto进行扫描

nmap -p80,443 10.0.1.0/24-oG - | nikto.pl -h -

## 3.Nmap参数详解

Nmap支持主机名,ip,网段的表示方式
例如:blah.highon.coffee, namp.org/24, 192.168.0.1;10.0.0-25.1-254

-iL filename                    从文件中读取待检测的目标,文件中的表示方法支持机名,ip,网段
-iR hostnum                     随机选取,进行扫描.如果-iR指定为0,则是无休止的扫描
--exclude host1[, host2]        从扫描任务中需要排除的主机         
--exculdefile exclude_file      排除文件中的IP,格式和-iL指定扫描文件的格式相同

主机发现

-sL                     仅仅是显示,扫描的IP数目,不会进行任何扫描
-sn                     ping扫描,即主机发现
-Pn                     不检测主机存活
-PS/PA/PU/PY[portlist]  TCP SYN Ping/TCPACK Ping/UDPPing发现
-PE/PP/PM使用ICMP echo, timestamp and netmask 请求包发现主机
-PO[prococol list]      使用IP协议包探测对方主机是否开启 
-n/-R不对IP进行域名反向解析/为所有的IP都进行域名的反响解析

扫描技巧

-sS/sT/sA/sW/sMTCP SYN/TCPconnect()/ACK/TCP窗口扫描/TCPMaimon扫描
-sU                             UDP扫描
-sN/sF/sXTCP Null,FIN,and Xmas扫描
--scanflags                     自定义TCP包中的flags
-sI zombie host[:probeport]     Idlescan
-sY/sZSCTP INIT/COOKIE-ECHO扫描
-sO                             使用IP protocol 扫描确定目标机支持的协议类型
-b “FTP relay host”             使用FTP bounce scan

指定端口和扫描顺序

-p                      特定的端口 -p80,443 或者 -p1-65535
-p U:PORT               扫描udp的某个端口, -p U:53
-F                      快速扫描模式,比默认的扫描端口还少
-r                      不随机扫描端口,默认是随机扫描的
--top-ports "number"扫描开放概率最高的number个端口,出现的概率需要参考nmap-services文件,ubuntu中该文件位于/usr/share/nmap.nmap默认扫前1000个
--port-ratio "ratio"扫描指定频率以上的端口

服务版本识别

-sV                             开放版本探测,可以直接使用-A同时打开操作系统探测和版本探测
--version-intensity "level"设置版本扫描强度,强度水平说明了应该使用哪些探测报文。数值越高,服务越有可能被正确识别。默认是7
--version-light                 打开轻量级模式,为--version-intensity 2的别名
--version-all                   尝试所有探测,为--version-intensity 9的别名
--version-trace                 显示出详细的版本侦测过程信息

脚本扫描

-sC                             根据端口识别的服务,调用默认脚本
--script=”Lua scripts”          调用的脚本名
--script-args=n1=v1,[n2=v2]     调用的脚本传递的参数
--script-args-file=filename     使用文本传递参数
--script-trace                  显示所有发送和接收到的数据
--script-updatedb               更新脚本的数据库
--script-help=”Lua script”      显示指定脚本的帮助

OS识别

-O              启用操作系统检测,-A来同时启用操作系统检测和版本检测
--osscan-limit  针对指定的目标进行操作系统检测(至少需确知该主机分别有一个open和closed的端口)
--osscan-guess  推测操作系统检测结果,当Nmap无法确定所检测的操作系统时,会尽可能地提供最相近的匹配,Nmap默认进行这种匹配

防火墙/IDS躲避和哄骗

-f; --mtu value                 指定使用分片、指定数据包的MTU.
-D decoy1,decoy2,ME             使用诱饵隐蔽扫描
-S IP-ADDRESS                   源地址欺骗
-e interface                    使用指定的接口
-g/ --source-port PROTNUM       使用指定源端口 
--proxies url1,[url2],...       使用HTTP或者SOCKS4的代理
--data-length NUM               填充随机数据让数据包长度达到NUM
--ip-options OPTIONS            使用指定的IP选项来发送数据包
--ttl VALUE                     设置IP time-to-live域
--spoof-mac ADDR/PREFIX/VEBDORMAC地址伪装
--badsum                        使用错误的checksum来发送数据包

Nmap 输出

-oN                     将标准输出直接写入指定的文件
-oX                     输出xml文件
-oS                     将所有的输出都改为大写
-oG                     输出便于通过bash或者perl处理的格式,非xml
-oA BASENAME            可将扫描结果以标准格式、XML格式和Grep格式一次性输出
-v提高输出信息的详细度
-d level                设置debug级别,最高是9
--reason                显示端口处于带确认状态的原因
--open只输出端口状态为open的端口
--packet-trace          显示所有发送或者接收到的数据包
--iflist                显示路由信息和接口,便于调试
--log-errors            把日志等级为errors/warings的日志输出
--append-output         追加到指定的文件
--resume FILENAME       恢复已停止的扫描
--stylesheet PATH/URL设置XSL样式表,转换XML输出
--webxml                从namp.org得到XML的样式
--no-sytlesheet         忽略XML声明的XSL样式表
其他nmap选项
-6                      开启IPv6
-A                      OS识别,版本探测,脚本扫描和traceroute
--datedir DIRNAME       说明用户Nmap数据文件位置
--send-eth / --send-ip  使用原以太网帧发送/在原IP层发送
--privileged            假定用户具有全部权限
--unprovoleged          假定用户不具有全部权限,创建原始套接字需要root权限
-V                      打印版本信息
-h                      输出帮助

## 4.例子

整个子网检测的Netbios

Nmap -sV -v-p 139,445 10.0.1.0/24
Starting Nmap 6.47 ( http://nmap.org ) at 2014-12-11 21:26 GMT
Nmap scan report fornas.decepticons 10.0.1.12
Host is up (0.014s latency).
PORT STATE SERVICE VERSION
139/tcpopennetbios-ssn Samba smbd 3.X (workgroup: MEGATRON)
445/tcpopennetbios-ssn Samba smbd 3.X (workgroup: MEGATRON)
Service detection performed. Please report any incorrect results at http://nmap.org/submit/.
Nmap done: 256 IP addresses (1 hosts up) scanned in28.74 seconds

Nmap 查找Netbios名称

nmap -sU --script nbstat.nse -p 137 10.0.1.12
Starting Nmap 6.47 ( http://nmap.org ) at 2014-12-11 21:26 GMT
Nmap scan report fornas.decepticons 10.0.1.12
Host is up (0.014s latency).
PORT STATE SERVICE VERSION
137/udpopennetbios-ns
Host script results:
|_nbstat: NetBIOS name: STARSCREAM, NetBIOS user: unknown, NetBIOS MAC: unknown (unknown)
Nmap done: 256 IP addresses (1 hosts up) scanned in28.74 seconds

如果开启Netbios服务,检查是否存在漏洞

nmap --script-args=unsafe=1 --script smb-check-vulns.nse -p 445 10.0.0.1
Nmap scan report forie6winxp.decepticons (10.0.1.1)
Host is up (0.00026s latency).
PORT STATE SERVICE
445/tcpopenmicrosoft-ds
Host script results:
| smb-check-vulns:
| MS08-067: VULNERABLE
| Conficker: Likely CLEAN
| regsvc DoS: NOT VULNERABLE
| SMBv2 DoS (CVE-2009-3103): NOT VULNERABLE
|_ MS07-029: NO SERVICE (the Dns Server RPC service is inactive)
Nmap done: 1 IP address (1 host up) scanned in5.45 seconds

根据扫描结果,发现存在MS08-067漏洞

## 5.参考

    原文
    http://highon.coffee/docs/nmap/
    Namp官网的完整手册
    https://svn.nmap.org/nmap/docs/nmap.usage.txt
    Nmap官方的中文手册
    http://nmap.org/man/zh/
    国内的一篇讲Nmap的,写的挺不错的
    http://blog.csdn.net/aspirationflow/article/details/7694274
    Man:
    man nmap

## 0x01 插件分类
nmap脚本主要分为以下几类,在扫描时可根据需要设置–script=类别这种方式进行比较笼统的扫描

  auth: 负责处理鉴权证书(绕开鉴权)的脚本 
  broadcast: 在局域网内探查更多服务开启状况,如dhcp/dns/sqlserver等服务 
  brute: 提供暴力破解方式,针对常见的应用如http/snmp等 
  default: 使用-sC或-A选项扫描时候默认的脚本,提供基本脚本扫描能力 
  discovery: 对网络进行更多的信息,如SMB枚举、SNMP查询等 
  dos: 用于进行拒绝服务攻击 
  exploit: 利用已知的漏洞入侵系统 
  external: 利用第三方的数据库或资源,例如进行whois解析 
  fuzzer: 模糊测试的脚本,发送异常的包到目标机,探测出潜在漏洞 intrusive: 入侵性的脚本,此类脚本可能引发对方的IDS/IPS的记录或屏蔽  malware: 探测目标机是否感染了病毒、开启了后门等信息 
  safe: 此类与intrusive相反,属于安全性脚本 
  version: 负责增强服务与版本扫描(Version Detection)功能的脚本 
  vuln: 负责检查目标机是否有常见的漏洞(Vulnerability),如是否有MS08_067

  (1) nmap --script=auth 192.168.137.*
  负责处理鉴权证书(绕开鉴权)的脚本,也可以作为检测部分应用弱口令
  (2)nmap --script=brute 192.168.137.*
  提供暴力破解的方式  可对数据库,smb,snmp等进行简单密码的暴力猜解
  (3)nmap --script=default 192.168.137.* 或者 nmap -sC 192.168.137.*
  默认的脚本扫描,主要是搜集各种应用服务的信息,收集到后,可再针对具体服务进行攻击
  (4)nmap --script=vuln 192.168.137.*
  检查是否存在常见漏洞
  (5)nmap -n -p445 --script=broadcast 192.168.137.4
  在局域网内探查更多服务开启状况
  (6)nmap --script external 202.103.243.110
  利用第三方的数据库或资源,例如进行whois解析

## 0x02 nmap按应用服务扫描
(1)vnc扫描:
  检查vnc bypass
  nmap  --script=realvnc-auth-bypass 192.168.137.4 
  检查vnc认证方式
  nmap  --script=vnc-auth  192.168.137.4 
  获取vnc信息
  nmap  --script=vnc-info  192.168.137.4

(2)smb扫描:
  smb破解
  nmap  --script=smb-brute.nse 192.168.137.4 
  smb字典破解
  nmap --script=smb-brute.nse --script-args=userdb=/var/passwd,passdb=/var/passwd 192.168.137.4 
  smb已知几个严重漏
  nmap  --script=smb-check-vulns.nse --script-args=unsafe=1 192.168.137.4   
  查看共享目录
  nmap -p 445  --script smb-ls --script-args ‘share=e$,path=\,smbuser=test,smbpass=test’ 192.168.137.4   
  查询主机一些敏感信息(注:需要下载nmap_service)
  nmap -p 445 -n –script=smb-psexec --script-args= smbuser=test,smbpass=test 192.168.137.4 
  查看会话
  nmap -n -p445 --script=smb-enum-sessions.nse --script-args=smbuser=test,smbpass=test 192.168.137.4   
  系统信息
  nmap -n -p445 --script=smb-os-discovery.nse --script-args=smbuser=test,smbpass=test 192.168.137.4 

(3)Mssql扫描:
  猜解mssql用户名和密码
  nmap -p1433 --script=ms-sql-brute --script-args=userdb=/var/passwd,passdb=/var/passwd 192.168.137.4   
  xp_cmdshell 执行命令
  nmap -p 1433 --script ms-sql-xp-cmdshell --script-args mssql.username=sa,mssql.password=sa,ms-sql-xp-cmdshell.cmd="net user" 192.168.137.4     
  dumphash值
  nmap -p 1433 --script ms-sql-dump-hashes.nse --script-args mssql.username=sa,mssql.password=sa  192.168.137.4     

(4)Mysql扫描:
  扫描root空口令
  nmap -p3306 --script=mysql-empty-password.nse 192.168.137.4 
  列出所有mysql用户
  nmap -p3306 --script=mysql-users.nse --script-args=mysqluser=root 192.168.137.4 
  支持同一应用的所有脚本扫描
  nmap --script=mysql-* 192.168.137.4 

(5)Oracle扫描:
  oracle sid扫描
  nmap --script=oracle-sid-brute -p 1521-1560 192.168.137.5 
  oracle弱口令破解
  nmap --script oracle-brute -p 1521 --script-args oracle-brute.sid=ORCL,userdb=/var/passwd,passdb=/var/passwd 192.168.137.5      

(6)其他一些比较好用的脚本
  nmap --script=broadcast-netbios-master-browser 192.168.137.4   发现网关 
  nmap -p 873 --script rsync-brute --script-args 'rsync-brute.module=www' 192.168.137.4  破解rsync 
  nmap --script informix-brute -p 9088 192.168.137.4    informix数据库破解 
  nmap -p 5432 --script pgsql-brute 192.168.137.4       pgsql破解 
  nmap -sU --script snmp-brute 192.168.137.4            snmp破解 
  nmap -sV --script=telnet-brute 192.168.137.4          telnet破解 
  nmap --script=http-vuln-cve2010-0738 --script-args 'http-vuln-cve2010-0738.paths={/path1/,/path2/}' <target>  jboss autopwn  
  nmap --script=http-methods.nse 192.168.137.4 检查http方法 
  nmap --script http-slowloris --max-parallelism 400 192.168.137.4  dos攻击,对于处理能力较小的站点还挺好用的 'half-HTTP' connections 
  nmap --script=samba-vuln-cve-2012-1182  -p 139 192.168.137.4

## use
  nmap --script http-brute --script-args http-brute.path=/manager/html -p80 abc.com
  nmap --script http-form-brute --script-args http-form-brute.path=/index.php,http-form-brute.uservar=userLogin,http-form-brute.passvar=userPassword,http-form-brute.onfailure=登陆失败 1.1.1.1


### 实例

    NMAP-V scanme.nmap.org
    此选项扫描机器上的所有保留的TCP端口 scanme.nmap.org。该-V 选项启用详细模式。

    NMAP-SS-O scanme.nmap.org/24
    推出针对每台机器出了256的IP所在Scanme所在的C类大小的网络上的隐形SYN扫描。它还试图确定什么操作系统每台主机的启动和运行上运行。这就要求,因为SYN扫描和操作系统检测的root权限。
   
    NMAP-SV-P 22,53,110,143,4564 198.116.0-255.1-127
    启动主机枚举和一个TCP扫描的每个第一次在198.116 B类地址空间的255个可能的8位子网的一半。这个测试是否系统上的标准端口,或者端口4564任何运行SSH,DNS,POP3或IMAP。对于任何这些端口发现开,版本检测是用来确定哪些应用程序正在运行。
   
    NMAP-V-IR 100000-PN-P 80
    要求Nmap来选择100,000台主机随机扫描和他们的Web服务器(端口80)。主机枚举被禁用 -PN自第一次发送几个探测,以确定主机是否是涨是浪费的,当你只探测每个目标主机上的一个端口反正。
   
    NMAP-PN-P80-OX logs/pb-port80scan.xml-OG logs/pb-port80scan.gnmap 216.163.128.20/20
    这种扫描4096的IP为任何Web服务器(不ping命令他们)并保存在的grepable和XML格式的输出。

### 官方下载及文档地址

    http://insecure.org/nmap/

### 适用于内外网的探测

    简单端口扫描: nmap -vv -sT(sS、sF、sU、sA) 192.168.0.1 -D 127.0.0.1(-D伪造的地址)

    OS检测: nmap -vv -sS -O 192.168.0.1

    RPC鉴别: nmap -sS -sR 192.168.0.1 Linux上的portmap就是一个简单的RPC服务,监听端口为111(默认),测试网络扫描和嗅探工 具包,其基本功能有三个,一是探测一组主机是否在线;其次是扫描 主机端口,嗅探所提供的网络服务;还可以推断主机所用的操作系统。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
   
    当SYN扫描不能用时,TCP Connect()扫描就是默认的TCP扫描:
    nmap -sT 192.168.1.0/24
   
    UDP扫描用-sU选项,UDP扫描发送空的(没有数据)UDP报头到每个目标端口:
    nmap -sU 192.168.1.0/24
   
    确定目标机支持哪些IP协议 (TCP,ICMP,IGMP等):
    nmap -sO 192.168.1.19
   
    探测目标主机的操作系统:
    nmap -O 192.168.1.19
    nmap -A 192.168.1.19
   
    另外,nmap官方文档中的例子:
    nmap -v scanme.nmap.org
    这个选项扫描主机scanme.nmap.org中 所有的保留TCP端口。选项-v启用细节模式。
   
    nmap -sS -O scanme.nmap.org/24
    进行秘密SYN扫描,对象为主机Saznme所在的“C类”网段 的255台主机。同时尝试确定每台工作主机的操作系统类型。因为进行SYN扫描 和操作系统检测,这个扫描需要有根权限。
   
    nmap -sV -p 22,53,110,143,4564 198.116.0-255.1-127
    进行主机列举和TCP扫描,对象为B类188.116网段中255个8位子网。这 个测试用于确定系统是否运行了sshd、DNS、imapd或4564端口。如果这些端口 打开,将使用版本检测来确定哪种应用在运行。
 
posted @ 2018-03-18 17:07  数字安全极客  阅读(292)  评论(0编辑  收藏  举报