zoukankan      html  css  js  c++  java
  • 2019-2020-2 网络对抗技术 20175318 Exp5 信息搜集与漏洞扫描

    一、原理与实践说明

    二、实践过程记录

    三、实验遇到的问题及解决方法
    四、实验总结与体会

    一、原理与实践说明
    1.实践目标

    信息搜集:渗透测试中首先要做的重要事项之一,搜集关于目标机器的一切信息

    • 间接收集

    • DNS记录扫描和枚举

    • CorpWatch:auxiliary/gather/corpwatch_lookup_name

    • 搜索引擎子域名搜集器:auxiliary/gather/searchengine_subdomains_collector

    • 在线搜索工具

    • GHDB

    • 设备搜索:shodan,censys,zoomeye

    • viewdns

    • 直接收集

    • 主机扫描:发现网络上的活动主机,modules/auxiliary/scanner/discovery

    • 端口扫描:发现主机上的开放端口,通过search portscan 命令查看MSF中的端口扫描模块

    • 版本探测:探测端口上的运行服务

    • SMB(auxiliary/scanner/smb/smb_)一种在 Microsoft Windows系统中使用网络文件共享的协议,已被证明是最容易被攻击的协议之一,它允许攻击者枚举目标文件和用户,甚至远程代码执行。

    • SSH(auxiliary/scanner/ssh)一个广泛使用的远程登录程序。

    • FTP(auxiliary/scanner/ftp)

    • SMTP(auxiliary/scanner/smtp/smtp_)

    • SNMP(auxiliary/scanner/snmp/snmp_enum)用于管理网络设备的协议,比如监控设备的状态信息,接口信息,网络接口的数据吞吐量等,通过SNMP扫描器可以找到特定系统的大量信息。如果目标系统为Windows且配置了SNMP(通常是RO/RW团体字符串),我们可以提取系统重启时间,系统上的用户名,系统网络信息,运行的服务等各种有价值的信息。

    • HTTP(auxiliary/scanner/http/)

    • 漏洞探测:探测服务是否有相应漏洞

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

    • 社会工程学

    • 漏洞扫描与Openvas

    2.实践内容概述

    • 各种搜索技巧的应用

    • DNS IP注册信息的查询

    • 基本的扫描技术:主机发现、端口扫描、OS及服务版本探测、具体服务的查点

    • 漏洞扫描:会扫,会看报告,会查漏洞说明,会修补漏洞

    3.基础问题回答

    哪些组织负责DNS,IP的管理。

    • 全球根服务器均由美国政府授权的ICANN统一管理,负责全球的域名根服务器、DNS和IP地址管理。
    • 地址支持组织(ASO)负责IP地址系统的管理
    • 域名支持组织(DNSO)负责互联网上的域名系统(DNS)的管理
    • 协议支持组织(PSO)负责涉及Internet协议的唯一参数的分配
    • 全球根域名服务器:绝大多数在欧洲和北美(全球13台,用A~M编号),中国仅拥有镜像服务器(备份)。
    • 全球一共有5个地区性注册机构:
    • ARIN主要负责北美地区业务
    • RIPE主要负责欧洲地区业务
    • APNIC主要负责亚太地区业务
    • LACNIC主要负责拉丁美洲美洲业务
    • AfriNIC负责非洲地区业务

    什么是3R信息。

    • 注册人(Registrant) →注册商(Registrar) →官方注册局(Registry)

    评价下扫描结果的准确性。

    • 扫描结果很准确,与实际情况几乎一致

    二、实践过程记录
    任务一:各种搜索技巧的应用

    1.搜索网址目录结构

    原理:暴力破解一般就是指穷举法,它的原理就是使用攻击者自己的用户名和密码字典,一个一个去枚举,尝试是否能够登录。
    使用方法:

    msfconsole
    use auxiliary/scanner/http/dir_scanner
    set THREADS 20
    set RHOSTS www.baidu.com
    exploit
    

    可以找到以下这些目录:

    2.检测特定类型的文件

    原理:

    • filetype能对搜索结果的文件类型进行限定,格式为“检索词 filetype:文件类型”
    • -能在检索结果中获取检索词的补集,格式为“检索词 -词语”
    • site能限制检索结果的来源,格式为“检索词 site:限制域名”(不要在“:”后的域名中输入“http:”和“www.”)
    • inurl能在网址中进行搜索,格式为“检索词inurl:检索词”
    • |表示布尔逻辑中的或者(or)关系,使用格式为“关键词1 | 关键词2”
    • space表示布尔逻辑中的交集(and)关系,使用格式为“关键词1 关键词2”

    高级搜索界面,高级搜索界面的入口在搜索引擎首页右上角“设置”->“高级搜索”。

    使用site:gov.cn filetype:xls 身份证号

    打开下载的文档,显示信息如下:(照片,身份证号,真实姓名已打码)

    有点可怕哈,不知不觉自己的身份信息就被传到网络上了

    3.使用traceroute命令进行路由侦查

    原理:traceroute命令利用ICMP协议定位用户计算机和目标计算机之间的所有路由器。TTL值可以反映数据包经过的路由器或网关的数量,通过操纵独立ICMP呼叫报文的TTL值和观察该报文被抛弃的返回信息,traceroute命令能够遍历到数据包传输路径上的所有路由器。本实验以侦查网易为例。
    方法:输入命令tracert www.126.com

    从左到右的5条信息分别代表了“生存时间”(每途经一个路由器结点自增1)、“三次发送的ICMP包返回时间”(共计3个,单位为毫秒ms)和“途经路由器的IP地址”(如果有主机名,还会包含主机名)。其中带有星号(*)的信息表示该次ICMP包返回时间超时。
    这是在网页上的traceroute:https://tools.ipip.net/traceroute.php

    任务二:DNS IP注册信息的查询

    1.whois查询

    原理:whois用来进行域名注册信息查询。

    方法:在终端输入whois qinghuan.site可查询到3R注册信息,包括注册人的姓名、组织和城市等信息。
    这是我自己申请的域名,可以查到这个域名是在阿里云注册的,我的名字,以及注册、到期时间

    注:进行whois查询时去掉www等前缀,因为注册域名时通常会注册一个上层域名,子域名由自身的域名服务器管理,在whois数据库中可能查询不到。

    2.nslookup,dig域名查询

    nslookup

    原理:nslookup可以得到DNS解析服务器保存的Cache的结果,但并不是一定准确的。

    方法:在终端输入nslookup qinghuan.site

    得,我主机IP查出来了

    dig

    原理:dig可以从官方DNS服务器上查询精确的结果。

    方法:在终端输入dig qinghuan.site

    除此之外,dig命令还有很多查询选项,每个查询选项被带前缀(+)的关键字标识。例如:

    • +[no]search:使用 [不使用] 搜索列表或 resolv.conf 中的域伪指令(如果有的话)定义的搜索列表。缺省情况不使用搜索列表。
    • +[no]trace:切换为待查询名称从根名称服务器开始的代理路径跟踪。缺省情况不使用跟踪。一旦启用跟踪,dig 使用迭代查询解析待查询名称。它将按照从根服务器的参照,显示来自每台使用解析查询的服务器的应答。
    • +[no]identify:当启用 +short 选项时,显示 [或不显示] 提供应答的 IP 地址和端口号。
    • +[no]stats:该查询选项设定显示统计信息:查询进行时,应答的大小等等。缺省显示查询统计信息。

    3.IP2Location 地理位置查询

    www.maxmind.com

    原理:www.maxmind.com网站可以根据IP查询地理位置。

    方法:利用ping www.baidu.com的查看网站的IP地址 -> 打开网站网页www.maxmind.com->在网站下方输入IP->点击前往查看结果

    www.ip-adress.com

    原理:IP-ADDRESS这个网站可以查询到更详细的关于IP的信息

    方法:网页初始界面会显示自己本机的IP地址,在左上角的框里可以输入想要查询的IP,如39.156.66.14为百度的IP

    4.IP2反域名查询

    原理:shodan搜索引擎可以进行反域名查询,可以搜索到该IP的地理位置、服务占用端口号,以及提供的服务类型.

    方法:打开网站,输入IP地址,可以看到地理位置,端口号和提供的服务具体信息:

    任务三:基本的扫描技术:主机发现、端口扫描、OS及服务版本探测、具体服务的查点
    主机发现

    1.PING

    原理:ping命令用发送ICMP报文的方法检测活跃主机

    方法:输入命令ping www.baidu.com

    2.metasploit中的arp_sweep模块和 udp_sweep 模块

    原理:arp_sweepudp_sweep都是metasploit中位于modules/auxiliary/scanner/discovery中的模块。arp_sweep使用ARP请求枚举本地局域网络中的所有活跃主机;udp_sweep模块除了可以探测到存活主机之外,还可以获得主机名称信息

    arp_sweep使用命令:

    msfconsole
    use auxiliary/scanner/discovery/arp_sweep //进入arp_sweep 模块
    show options //查询模块参数
    set RHOSTS 192.168.234.0/24 //用set进行hosts主机段设置
    set THREADS 50 //加快扫描速度
    run //执行run进行扫描
    

    192.168.234.128为我另一个虚拟机的IP地址

    udp_sweep使用方法:

    msfconsole
    use auxiliary/scanner/discovery/udp_sweep //进入udp_sweep 模块
    show options //查询模块参数
    set RHOSTS 192.168.234.0/24 //用set进行hosts主机段设置
    set THREADS 50 //加快扫描速度
    run //执行run进行扫描
    

    3.nmap -sn

    nmap相关参数如下:

    -sS:TCP SYN扫描,可以穿透防火墙;
    -sA:TCP ACK扫描。有时候由于防火墙会导致返回过滤/未过滤端口;
    -sP:发送ICMP echo探测;
    -sT:TCP connect扫描,最准确,但是很容易被IDS检测到,不推荐;
    -sF/-sX/-sN:扫描特殊的标志位以避开设备或软件的监测;
    -O:启用TCP/IP协议栈的指纹特征信息扫描以获取远程主机的操作系统信息;
    -sV:获取开放服务的版本信息;

    原理:nmap -sn 参数可以用来探测某网段的活跃主机

    方法:输入命令nmap -sn 192.168.234.0/24

    端口扫描

    nmap -PU

    原理:nmap -PU参数是对UDP端口进行探测,与udp_sweep模块功能相同。

    方法:输入命令nmap -PU 192.168.234.0/24

    版本探测

    1.nmap -O

    原理:nmap -O选项让Nmap对目标的操作系统进行识别,获取目标机的操作系统和服务版本等信息

    方法:输入命令nmap -O 192.168.234.128

    2.nmap -sV

    原理:nmap -sV查看目标主机的详细服务信息

    方法:输入命令nmap -sV -Pn 192.168.234.128,其中-Pn是在扫描之前,不发送ICMP echo请求测试目标

    具体服务的查点

    metasploit中有许多相关工具,大部分都在Scanner辅助模块,常以[service_name]_version(用以遍历主机,确定服务版本)和[service_name]_login(进行口令探测攻击)命名。

    1.Telnet服务扫描

    原理:telnet命令用于登录远程主机,对远程主机进行管理。

    方法:

    msfconsole
    use auxiliary/scanner/telnet/telnet_version //进入telnet模块
    set RHOSTS 192.168.234.0/24 // 扫描192.168.234.0网段
    set THREADS 50 //提高查询速度
    run
    


    2.SSH服务

    原理:SSH(“安全外壳”)协议是用于从一个系统安全远程登录到另一个的方法。用户通过客户端 - 服务器架构格式的不安全网络使用安全通道,用于将SSH客户端与SSH服务器连接起来。

    方法:

    msfconsole
    use auxiliary/scanner/ssh/ssh_version //进入ssh模块
    set RHOSTS 192.168.234.0/24 //扫描192.168.234.0网段
    set THREADS 50 //提高查询速度
    run
    

    3.Oracle数据库服务查点

    方法:

    msfconsole
    use auxiliary/scanner/oracle/tnslsnr_version
    show options
    set RHOSTS 192.168.234.0/24 //扫描192.168.234.0网段
    set THREADS 200 //提高查询速度
    run
    

    漏洞扫描————安装使用OpenVAS

    1.安装OpenVAS

    apt-get update
    apt-get dist-upgrade
    apt-get install openvas
    openvas-setup
    

    检查安装结果:

    openvas-check-setup
    

    安装完成后会自动生成管理员账号和密码:

    2.登录

    3.新建Target,开始扫描

    在菜单栏选择"Scans"->"Tasks"
    点击"Wizard","Task Wizard"新建一个任务向导,在栏里输入待扫描主机的IP地址"192.168.234.128",并单击"Start Scans"确认,开始扫描

    4. 查看并分析扫描结果

    CPE(Common Platform Enumeration):以标准化方式为软件应用程序、操作系统及硬件命名的方法。
    CVE:一个条目列表,每个条目包含一个识别号、一个描述和至少一个公开的已知网络安全漏洞的公共引用。CVE条目用于世界各地的众多网络安全产品和服务,包括NVD。
    NVT:网络漏洞测试
    

    打开该扫描结果的详细信息,并点击其中的“Full and fast”:

    点击进入Databases查看详细结果,其中标注了漏洞的危险等级:

    点开一个危险等级较高的漏洞:

    详细描述如下:

    • Summary是该漏洞的描述,意思是IBM DB2容易出现多个漏洞。
    • Vulnerability Scoring是危险评分,分数越大,漏洞越危险
    • Solution是关于该漏洞的解决方案:从引用的建议中应用适当的修复程序。
      三、实验遇到的问题及解决方法

    在进行漏洞扫描时遇到:警告:SecInfo Database Missing (安全信息数据库丢失)

    解决方法:
    使用openvas-check-setup | grep FIX,并使用greenbone-certdata-sync进行修复

    在终端中使用代理:

    root@LHR-kali:~/桌面# export http_proxy="http://192.168.1.13:1337"
    
    


    四、实验总结与体会

    信息收集作为渗透测试中首先要做的重要事项之一,在整个过程中起到了至关重要的作用,我们掌握的信息越多,渗透成功的机会越大。通过本次实验,我学习并利用各种工具对主机、端口、版本、网络服务等进行了扫描,实现了基本的信息收集。并在实验后期,使用Openvas实现了漏洞扫描。Openvas安装也没那么费时间,下载速度慢挂个代理就行了,反正我那香港的服务器闲着也是闲着。
    这次的实验是让我们对信息收集及漏洞扫描进行了解及操作,无论在什么是事情上,我觉得对于信息的收集都是至关重要的,只有通过信息的收集,我们才会对一件事情进行充分、具体的了解,将各个信息进行整合,就会得到一个系统的轮廓,会让我们更加方便具体的去深入研究,所以我觉得这一方面在日后的学习工作中还是应该加强。

  • 相关阅读:
    linux 信号处理 二 (信号的默认处理)
    linux 信号处理 一 (基本概念)
    POSIX 消息队列 之 参数说明
    System V 消息队列 实例
    KDB支持单步调试功能(ARM架构)
    找工作笔试面试那些事儿(16)---linux相关知识点(1)
    Central Europe Regional Contest 2012 Problem H: Darts
    计算机数据结构之——什么是艺术品?
    老罗android开发视频教程 下载地址
    HTML5 实现拖拽
  • 原文地址:https://www.cnblogs.com/L1079991001/p/12737235.html
Copyright © 2011-2022 走看看