nmap在网络和渗透中使用相当频繁,相关教程也层出不穷。在此,我只整理出最实用的,言简意赅,方便自己,方便他人。


一、nmap介绍

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

二、nmap功能

1.主机发现;   //探测存活主机

2.端口扫描;   //探测开放端口及端口的服务

3.版本侦测;   //探测服务的版本,eg:httpd 1.0

4.OS检测。    //检测目标的操作系统。

5.漏洞扫描。   //配合一些特定漏洞扫描脚本进行漏扫(用的极少,漏洞一般用专业的漏扫工具)

端口扫描原理:

以ping(ICMP协议)、发TCP/UDP包、ARP包、SYN/ACK三次握手等等十多种探测方式。

端口状态:

(1) open:端口是开放的。

(2) closed:端口是关闭的。

(3) filtered:端口被防火墙IDS/IPS屏蔽,无法确定其状态。

(4) unfiltered:端口没有被屏蔽,但是否开放需要进一步确定。

三、nmap参数

1.主机发现:

-sL:仅仅是显示,扫描的IP数目,不会进行任何扫描(较少用,意义不大)。

-sn:ping扫描,即主机发现。

-Pn:不检测主机存活,默认视目标为存活主机,直接对其进行端口探测。

-PS/PA/PU/PY:TCP SYN Ping/TCP ACK Ping/UDP Ping发现。

-PE/PP/PM:使用ICMP echo, timestamp and netmask 请求包发现主机。

-P0:在扫描之前,不ping主机;有些网络防火墙可能禁止ICMP请求包,使用这种扫描类型可以跳过ping测试。

-n/-R:-n表示不进行DNS解析,以加快扫描速度;-R表示总是进行DNS解析。

-exclude:排除指定主机。(比如不扫某个网段中的某个IP)

-excludefile:排除指定文件中的主机。(不扫某个网段中的某些IP)

2.端口扫描:

-p:指定端口扫描,eg:-p 80,8080,3306(指定端口)-p 1-65535(全端口),如未指定默认扫描1000个最有可能开放的TCP端口。

-F:快速扫描,扫描常见的100个TCP端口。

3.版本侦测:

-sV:开放版本探测,可以直接使用-A同时打开操作系统探测和版本探测。

4.OS检测:

-O:启用操作系统检测,可以直接使用-A同时打开操作系统探测和版本探测。

5.漏洞扫描:

-sC:根据对应的端口选择相应的漏洞脚本。

6.扫描技巧:

-v:强烈推荐使用这个选项,它会给出扫描过程中的详细信息。

-A:打开操作系统探测和版本探测(可同时代替-sV和-O),进攻性(Aggressive)方式扫描。

-T4:指定扫描过程使用的时序(Timing),总有6个级别(0-5),级别越高,扫描速度越快,但也容易被防火墙或IDS检测并屏蔽掉,在网络通讯状况良好的情况推荐使用T4,不做设置nmap默认是T3;

-sS/sT/sA/sW/sM:SYN/TCP connect()/ACK/TCP窗口扫描/ Maimon扫描。

-sU:以UDP扫描。

-sP:ping扫描,用ping方式检查网络上哪些主机正在运行。当主机阻塞ICMP  echo请求包是ping扫描是无效的。nmap在任何情况下都会进行ping扫描,只有目标主机处于运行状态,才会进行后续的扫描。

-sN/sF/sX:以TCP Null,FIN,and Xmas扫描。

-sY/sZ:SCTP INIT/COOKIE-ECHO 扫描(较少使用)。

-sO:使用IP protocol 扫描确定目标机支持的协议类型(较少使用)。

-b “FTP relay host”:使用FTP bounce scan(较少使用)。。

7.输入输出:

-iL:从文件中读取待检测的目标,文件中的表示方法支持机名,ip,网段。

-oX:输出结果为xml文件。

-oG:输出便于通过bash或者perl处理的格式,非xml。

四、常用组合

1.GUI下nmap默认参数:

nmap -T4 -A –v + target   //以默认的方式扫描存活主机、开放端口、服务、版本、OS信息,不是全端口扫描,适合新手。

2.探测某一IP全端口:

nmap –p 1-65535 192.168.1.110   //根据时间和效率可以选加-Pn、-v、-T4、-A等等组合

3.仅探测某一网段的存活主机:

nmap -sP 10.0.0.0/24   //也可加一些其他参数,就不列举了

4.探测某一网段的存活主机的开放端口:

nmap –T4 –A –v -p 1-65535 –sP 10.0.0.0/24 –oX 10.0.0.0.xml

The End!

NMAP实用手册的更多相关文章

  1. 实用手册:130+ 提高开发效率的 vim 常用命令

    Vim 是从 vi 发展出来的一个文本编辑器.代码补完.编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用.和 Emacs 并列成为类 Unix 系统用户最喜欢的编辑器.这里收录了130+程 ...

  2. 【转载】Exchange 2010配置与安装实用手册

    Exchange 2010配置与安装实用手册 在Exchange 2010配置的时候主要分三大部分,这分别是网络配置.准备存储以及相关的安装策略和过程.同时还需要注意和其他的Windows软件相协调. ...

  3. Oracle 数据库基本操作——实用手册、表操作、事务操作、序列

    目录: 0. 参考链接与参考手册1. oracle 实用(常用操作)指令2. 数据库基本操作语法 a) 表操作 1)创建表 2)更新表 3)删除表 4)查询 b) 事务操作 c) 序列操作 1)创建序 ...

  4. nmap中文手册

    译注该Nmap参考指南中文版由Fei Yang <fyang1024@gmail.com>和Lei Li<lilei_721@6611.org> 从英文版本翻译而来. 我们希望 ...

  5. linux sort 命令实用手册

    Linux 中的sort 命令是一个很实用的工具,用于对文本内容以行为单位进行ASCII 码排序,默认按照升序进行排序(当然也可以按照降序). sort 命令的格式如下: sort `参数` `文件名 ...

  6. linux awk 命令实用手册

    0,简介 Linux awk 是一个实用的文本处理工具,它不仅是一款工具软件,也是一门编程语言.awk 的名称来源于其三位作者的姓氏缩写,其作者分别是Alfred Aho,Peter Weinberg ...

  7. Nmap 操作手册 - 完整版

    目录 Nmap - 基础篇 Nmap 安装 RedHat Windows Debina & Ubuntu Others Linux Nmap 参数(简单版) 目标说明 主机发现 扫描技术 端口 ...

  8. Nmap扫描手册

    By:WHILE扫描类-sTTCP connect()扫描,完整的通话连接,容易被检测,会被记录日志.-sSTCP同步扫描,不完整的通话连接,很少有系统会记入日志.-sUUDP扫描-sAACK扫描用来 ...

  9. 端口扫描程序nmap使用手册

        其实还是建议看英文的man,对以后学习其他东西很有帮助的:) 摘要 nmap是一个网络探测和安全扫描程序,系统管理者和个人可以使用这个软件扫描大型的网络,获取那台主机正在运行以及提供什么服务等 ...

随机推荐

  1. C++笔记(3):一些C++的基础知识点

     前言: 找工作需要,最近看了下一些C++的基本概念,为范磊的<零起点学通C++>,以下是一些笔记. 内容: delete p;只是删除指针p指向内存区,并不是删除指针p,所以p还是可以用 ...

  2. Android中BroadcastReceiver广播

    BroadCastReceiver 简介 广播接收者( BroadcastReceiver )用于接收广播 Intent ,广播 Intent 的发送是通过调用 Context.sendBroadca ...

  3. Windows Azure Web Site (12) Azure Web Site配置文件

    <Windows Azure Platform 系列文章目录>  本文将介绍如何在Azure Web Site里配置连接字符串. 本文分为以下几个步骤: 1.在本地ASP.NET项目使用W ...

  4. CSS易混淆知识点总结与分享-定位与布局

    CSS定位有四种模式:static.relative.absolute.fixed,其它static是默认值,下面分别讲解下各自的特点: static:静态定位,处于动态布局流中,按照页面中的各元素先 ...

  5. C#密封类

    密封类 密封类使用sealed修饰符声明. 密封类中不可能有抽象方法[因为:抽象方法必须在抽象类中,而抽象类不能是密封的或者是静态的,也就是说abstract 和sealed不能同时修饰一个类]   ...

  6. asp.net判断FileUpload选择的文件是否是图片

    假如keleyi.aspx页面中有一个ID为fuHovertree的FileUpload控件,那么C#代码怎么判断fuHovertree选择的文件是否是图片呢? 代码如下: HttpPostedFil ...

  7. iOS学习笔记——触控与手势

    触控 此部分内容已学良久,恨记之甚晚,忙矣,懒矣!本文简而记焉,恐日后忘也. 在iOS的触控事件中,有触控.事件以及响应者这三个角色,一个触摸则代表了一只手指和屏幕接触这个动作所包含的信息:而事件则包 ...

  8. 这几天做完简易酒店管理系统,对Sql Server执行计划的浅显了解。

    我是一名大三的小学生,今天开始我的第一篇博客,最近随便做了一个简易的酒店管理系统,对sql执行计划有了初步的了解. 查看上面语句的预估执行计划,在工具栏中有这个按钮 聚集索引扫描被称为Index Sc ...

  9. 【SQL】分配函数一枚[AllotToTable]

    适用环境:MSSQL 2005+.其中05需修改部分语句的写法才行,如: --变量的声明和赋值需分开写 --需改为如下 --05不支持+=这样的复合运算符 --需改为如下 功能: 将一个数字(整数或有 ...

  10. java.lang.IllegalStateException: Failed to read Class-Path attribute from manifest of jar file:/XXX

    出现这个问题的解决方案就是将原有的jar删除  然后重新下载过一遍就可以使用了  我估计是元数据等损坏了