端口
nmap –A:全面扫描nmap –Pn:不检测主机存活。不用ping,当我们扫描一个有防火墙保护而封锁 ping 探针主机的时候是非常有用的。+nmap –sP:只是普通的ping扫描,主要用户检测主机是否存活nmap –sL:扫描的所有主机的列表nmap –sn:Ping所有已连接的活动网络主机nmap –sT:TCP扫描.扫描的速度快,准确性高,但是容易被防火墙和IDS(防入侵系统)发现nmap –sS:syn扫描。这是一种秘密的扫描方式之一.需要root权限(对于windows用户来说,是没有root权限这个概念的,root权限是linux的最高权限,对应windows的管理员权限)+nmap –p:后面跟指定的扫描端口nmap –n:后面对应的IPnmap –O:操作系统识别nmap –sV:服务的版本识别nmap –F:快速扫描namp -T 4:一般使用4(Aggressive模式假设用户具有合适及可靠的网络从而加速扫描)
常用nmap -O -Pn -sS -sV -T 4 192.168.***.***
漏洞
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)mysql-brute: 使用默认密码暴力破解mysql
最好的 NMAP 扫描策略
适用所有大小网络最好的 nmap 扫描策略
主机发现,生成存活主机列表
$ nmap -sn -T4 -oG Discovery.gnmap 192.168.56.0/24$ grep "Status: Up" Discovery.gnmap | cut -f 2 -d ' ' > LiveHosts.txt
端口发现,发现大部分常用端口
http://nmap.org/presentations/BHDC08/bhdc08-slides-fyodor.pdf$ nmap -sS -T4 -Pn -oG TopTCP -iL LiveHosts.txt$ nmap -sU -T4 -Pn -oN TopUDP -iL LiveHosts.txt$ nmap -sS -T4 -Pn --top-ports 3674 -oG 3674 -iL LiveHosts.txt
端口发现,发现全部端口,但 UDP 端口的扫描会非常慢
$ nmap -sS -T4 -Pn -p 0-65535 -oN FullTCP -iL LiveHosts.txt$ nmap -sU -T4 -Pn -p 0-65535 -oN FullUDP -iL LiveHosts.txt
显示 TCP\UDP 端口
$ grep "open" FullTCP|cut -f 1 -d ' ' | sort -nu | cut -f 1 -d '/' |xargs | sed 's/ /,/g'|awk '{print "T:"$0}'$ grep "open" FullUDP|cut -f 1 -d ' ' | sort -nu | cut -f 1 -d '/' |xargs | sed 's/ /,/g'|awk '{print "U:"$0}'
侦测服务版本
$ nmap -sV -T4 -Pn -oG ServiceDetect -iL LiveHosts.txt
扫做系统扫描
$ nmap -O -T4 -Pn -oG OSDetect -iL LiveHosts.txt
系统和服务检测
$ nmap -O -sV -T4 -Pn -p U:53,111,137,T:21-25,80,139,8080 -oG OS_Service_Detect -iL LiveHosts.txt