基于Linux系统的开放的应用软件很多,常常令人眼花缭乱、手足无措,为了让大家在选择应用软件的时候目标明确,本刊特地挑选了一些比较实用的软件进行了安装测试,这次就先把有关Nmap扫描器的测试告诉大家。
1.为什么是Nmap
在黑客发起攻击前,对目标机的相关信息进行收集是必须的,同样,网络管理员需要随时了解服务器的运行状态,及时发现安全隐患。所以对双方来说,一个好的
端口扫描器能够帮助你事半功倍。Nmap就是一个非常出色的扫描器,Info
World这样评价Nmap:如果你的目的是在40000英尺高度上看看你的网络,那基于Windows的端口扫描工具就足够了,但是如果你真的关心你的
网络安全,并努力想找到那些可能被侵入者发现的系统漏洞,那你最好花点时间去安装并使用一个Linux工具——Nmap(见图1)。
Nmap是一个针对大型网络的端口扫描工具,当然对一台主机来说,它也工作得非常好。它的设计指导思想是:TMTOWTDI(Theres More
Than One Way To Do
It)。有时你需要扫描速度,有时你主要考虑健壮性,可能在有些情况下你希望能够穿过防火墙。你可能希望扫描各种不同的协议(UDP,TCP,ICMP等
等)。只要你使用Nmap,所有这些愿望都能得到实现。因为Nmap集成了几乎所有的扫描功能!同时它也是一些著名的安全工具所必须的,如Nessus
等。Nmap是在免费软件基金会的GNU General Public License
(GPL)下发布的,可从www.insecure.org/Nmap站点上免费下载。
Nmap的使用语法相当简单。Nmap的不同选项和-s标志组成了不同的扫描类型,比如:一个Ping-scan命令就是“-sP”。在确定了目标主机和
网络之后,即可进行扫描。最好是以root来运行Nmap,这样将会使Nmap的功能大大地增强,因为超级用户可以创建便于Nmap利用的定制数据包。
在目标机上,Nmap运行灵活。使用Nmap进行单机扫描或是整个网络的扫描很简单,只要将带有“/mask”的目标地址指定给Nmap即可。地址是
“victim/24”, 则目标是C类网络,地址是“victim/16”, 则目标是B类网络。另外,Nmap允许你使用各类指定的网络地址,比如
192.168.7.*,是指192.168.7.0/24, 或 192.168.7.1,4,8-12,对所选子网下的主机进行扫描。
2.一些常用使用方法
*Ping扫描
使用Nmap扫描整个网络寻找目标,已确定目标机是否处于连通状态。通过使用"-sP"命令,进行ping扫描。缺省情况下,Nmap给每个扫描到的主
机发送一个ICMP echo和一个TCP ACK,
主机对任何一种的响应都会被Nmap得到,扫描速度非常快,在很短的时间内可以扫描一个很大的网络。
举例:扫描192.168.7.0网络:
# Nmap -sP 192.168.7.0/24
Starting Nmap V. 2.12 by Fyodor (fyodor@dhp.com, www.insecure.org/Nmap/)
Host (192.168.7.11) appears to be up.
Host (192.168.7.12) appears to be up.
Host (192.168.7.76) appears to be up.
Nmap run completed -- 256 IP addresses (3 hosts up) scanned in 1 second
一个TCP"ping"将发送一个ACK到目标网络上的每个主机。网络上的主机如果在线,则会返回一个TCP
RST响应。使用带有ping扫描的TCP
ping选项,也就是"PT"选项可以对网络上指定端口进行扫描,它将可能通过目标边界路由器甚至是防火墙。并且,值得注意的是,被探测的主机上的目标端
口无须打开,关键取决于是否在网络上。
例如:
# Nmap -sP -PT80 192.168.7.0/24
TCP probe port is 80
Starting Nmap V. 2.12 by Fyodor (fyodor@dhp.com, www.insecure.org/Nmap/)
Host (192.168.7.11) appears to be up.
Host (192.168.7.12) appears to be up.
Host (192.168.7.76) appears to be up.
Nmap run completed -- 256 IP addresses (3 hosts up) scanned in 1 second
通过对端口80的指定,被扫描的机器可能没有打开80端口,但仍然会返回一个对ACK标志的响应,所以状态就是up。
*端口扫描
通常情况下,当Nmap的使用者确定了网络上运行的主机处于连通状态,下一步的工作就是进行端口扫描,端口扫描使用-sT参数:
#Nmap -sT 172.16.4.227
Starting Nmap V. 2.2-BETA3 by Fyodor (fyodor@dhp.com, www.insecure.org/Nmap/)
Interesting ports on backup.ccidnet.com (172.16.4.227):
Port State Protocol Service
21 open tcp ftp
22 open tcp ssh
23 open tcp telnet
25 open tcp smtp
111 open tcp sunrpc
1025 open tcp listen
1521 open tcp ncube-lm
2401 open tcp cvspserver
Nmap run completed -- 1 IP address (1 host up) scanned in 1 second
通过端口扫描,可以发现目标目前打开的服务和端口,Nmap支持不同类别的端口扫描TCP连接, TCP SYN, Stealth FIN, Xmas Tree,Null和UDP扫描等等。
*隐蔽扫描
一个攻击者使用TCP连接扫描很容易被发现,因为Nmap将使用connect()系统调用打开目标机上相关端口的连接,并完成三次TCP握手,很可能
被系统记录下来。如果你不愿意在扫描时使其信息被记录在目标系统日志上,就可以使用Nmap的TCP
SYN扫描,它很少会在目标机上留下记录,三次握手的过程从来都不会完全实现。通过发送一个SYN包(是TCP协议中的第一个包)开始一次SYN的扫描。
任何开放的端口都将有一个SYN|ACK响应。然而,攻击者发送一个RST替代ACK,连接中止。三次握手得不到实现,也就很少有站点能记录这样的探测。
如果是关闭的端口,对最初的SYN信号的响应也会是RST,让Nmap知道该端口不在监听。"-sS"命令将发送一个SYN扫描探测主机或网络
#Nmap -sS 172.16.4.227
Starting Nmap V. 2.2-BETA3 by Fyodor (fyodor@dhp.com, www.insecure.org/Nmap/)
Interesting ports on backup.ccidnet.com (172.16.4.227):
Port State Protocol Service
21 open tcp ftp
22 open tcp ssh
23 open tcp telnet
25 open tcp smtp
111 open tcp sunrpc
1025 open tcp listen
1521 open tcp ncube-lm
2401 open tcp cvspserver
Nmap run completed -- 1 IP address (1 host up) scanned in 0 seconds
虽然SYN扫描可能不被注意,但他们仍会被一些入侵检测系统捕捉。Stealth FIN,Xmas树和Null
scans可用于躲避包过滤和可检测进入受限制端口的SYN包。这三个扫描器对关闭的端口返回RST,对开放的端口将吸收包。一个
FIN“-sF”扫描将发送一个FIN包到每个端口。
*UDP扫描
如果一个攻击者寻找一个流行的UDP漏洞,比如 rpc漏洞或Back Orifice。为了查出哪些端口在监听,则进行UDP扫描,即可知哪些端口对UDP是开放的。Nmap将发送一个O字节的UDP包到每个端口。如果主机返回端口不可达,则表示端口是关闭的。
#Nmap -sU 172.16.4.227
WARNING: -sU is now UDP scan -- for TCP FIN scan use -sF
Starting Nmap V. 2.2-BETA3 by Fyodor (fyodor@dhp.com, www.insecure.org/Nmap/)
Interesting ports on backup.ccidnet.com (172.16.4.227):
Port State Protocol Service
111 open udp sunrpc
Nmap run completed -- 1 IP address (1 host up) scanned in 2 seconds
*操作系统识别
通常一个入侵者可能对某个操作系统的漏洞很熟悉,能很轻易地进入此操作系统的机器。一个常见的选项是TCP/IP上的指纹,带有"-O"选项决定远程操
作系统的类型。这可以和一个端口扫描结合使用,但不能和ping扫描结合使用。Nmap通过向主机发送不同类型的探测信号,缩小查找的操作系统的范围。指
纹验证TCP包括使用FIN探测技术发现目标机的响应类型。BOGUS的标志探测,发现远程主机对发送的带有SYN包的不明标志的反应,TCP
初始序列号(ISN)取样发现ISN数值的样式,也可以用另外的方式决定远程操作系统。有一篇权威的关于指纹(fingertprinting)的文章,
作者:Fyodor,也是namp的作者,参见地址:http://www.insecure.org/Nmap/Nmap-
fingerprinting-article.html
#Nmap -sS -O 172.16.4.227
Starting Nmap V. 2.2-BETA3 by Fyodor (fyodor@dhp.com, www.insecure.org/Nmap/)
Interesting ports on backup.ccidnet.com (172.16.4.227):
Port State Protocol Service
21 open tcp ftp
22 open tcp ssh
23 open tcp telnet
25 open tcp smtp
111 open tcp sunrpc
1025 open tcp listen
1521 open tcp ncube-lm
2401 open tcp cvspserver
TCP Sequence Prediction: Class=random positive increments
Difficulty=2110423 (Good luck!)
Remote operating system guess: Linux 2.1.122 - 2.1.132; 2.2.0-pre1 - 2.2.2
Nmap run completed -- 1 IP address (1 host up) scanned in 1 second
在大多数情况下,Nmap对操作系统的检测是很准确也是很有效的。通常来说,工程师对Nmap的认识是一个出色的黑客工具,但实际上,随着网络安全问题
越来越专业,网络安全工程师的安全防护手段也在不断增加,道高一尺,魔高一丈,要想在攻防中处于有利地位,首先要研究对手的方式和手段。从这个意义上
讲,Nmap也是网络管理员的有力武器。
阅读(3882) | 评论(0) | 转发(1) |