2017-2018-2 20179204《网络攻防实践》第四周学习总结

第1节 教材学习内容总结

本周学习了教材第四章的内容。教材第四章讲了“网络嗅探与协议分析”,并介绍了几种工具和实践作业。

1.网络嗅探

本节介绍了网络嗅探技术定义、分类、原理、实现方式、常用软件。

  • 网络嗅探技术 sniff

是一种黑客窃听技术,截获数据报文(经过封包处理之后的二进制数据),结合网络协议分析技术。实现工具为网络嗅探器(sniffer)。

特点:被动性、非干扰性、隐蔽性。是一把双刃剑。

  • 技术与工具分类

按照所监听的链路层网络进行分类:以太网——有线局域网流行的链路层协议wifi——无线局域网流行的链路层协议,二者是主要监听对象。分为:无线嗅探器、有线嗅探器。

二者联系:在对数据包实际进行破解和分析时一样,但无线嗅探器可以读取和分析符合无线传输协议的数据包。

或按照实现方式分为:软件嗅探器(慢、不全面、便宜)、硬件嗅探器(快、全面、贵)。

  • 原理

以太网工作支持一种混杂模式:该模式下的网卡能够接收一切通过它连接共享通信媒介的数据帧,而不管数据帧是否是传给它的。

部署有线局域网时分为共享式网络(集线器连接,拓扑基于总线方式,物理上是广播的)和交换式网络(交换机连接,检查“MAC地址-端口映射表”,只允许匹配成功的数据包通过并发送到特定端口,因此可以有效避免网络广播风暴)

三种攻击方式:MAC地址洪泛攻击、MAC欺骗、ARP欺骗。

  • 实现

    	类UNIX平台下:内核态的BPF和用户态的libpcap抓包工具库实现。
    	windows平台下:内核态的NPF和用户态的winpcap。
    
  • 软件

    	类UNIX平台:libpcap、tcpdump(命令行模式)、wireshark,其它如snort、dsniff、sniffit、linux_sniffer。
    	windows平台:wireshark、snifferpro、windump
    

tcpdump嗅探器:课本给出的使用参考Linux tcpdump命令详解

  • 检测与防范

检测较为困难:

  	linux下 同一主机,检查网卡是否运行中混杂模式下;其他主机,基于混杂模式下操作系统和协议栈的不同特性,构造MAC地址有效而IP地址无效的ICMP Echo请求,看是否返回应答包。
  	windows下 检查一个包MAC地址前八位是否为0xff;响应时间。 

防范:

  	采用安全的网络拓扑,升级为交换式网络,合理分段;
  	用静态ARP或者MAC-端口映射表代替动态机制;
  	重视网络数据传输的集中位置点的安全防范,如网关、路由器和交换机等;
  	避免使用明文传输口令或敏感信息的网络协议,使用加密及安全增强的网络协议。

2.网络协议分析

  • 原理:对网络上传输的二进制数据包进行解析,恢复出各层网络协议信息以及传输内容。与解包原理类似但又有不同。本节还介绍了协议分析的典型过程及步骤。
  • 技术实现:介绍了tcpdump、wireshark、snort的源码实现方式。
  • wireshark使用:介绍了功能、主窗口、过滤语句等。

p137实践见第2节。

第2节 教材学习中的问题和解决过程

p137动手实践——攻防对抗

  攻击方kali:192.168.11.68
  防守方seed:192.168.11.214
  彼此可以ping通
  攻击方分别使用nmap -sT/-sS/-sU进行TCP connect()扫描、TCP SYN扫描、UDP端口扫描;
  防守方使用sudo tcpdump -i eth6 host 192.168.11.68 -w 1.pcapng/2.pcapng/3.pcapng嗅探
  将三个抓包文件拖入wireshark进行分析。






第3节 kali视频(11-15)学习

11.漏洞分析之OpenVAS使用

  • 查看metasploitable IP地址:192.168.199.214,可以ping通。
  • 访问OpenVAS web管理界面。对界面进行学习。
  • 添加扫描目标。configuration——targets,默认目标是本机。点击new target,设置名字、主机名,其他保持默认即可。
  • 创建扫描任务。scans——tasks——new task,创建名字、其他可以保持默认(full and fast)——create task。

  • 主界面出现一行扫描任务和状态,点击start。点击任务名“scan”查看进度、漏洞。
  • 查看漏洞详细信息,可以导出pdf报告文件(scan report)。

  • 也可以quickstart一个扫描。

可以参考这篇文章对各个界面模块的介绍:OpenVas 漏洞扫描器使用教程

12.漏洞分析之扫描工具

除了OpenVAS,kali下还有web漏洞扫描器golismero、nikto以及系统信息扫描收集工具lynis、unix-privesc-check。

  • golismero

自带测试工具,也可以导入其他扫描工具的结果,由python编写,也没有系统依赖性。

有四类插件:

  终端输入golismero --help,查看帮助信息
  输入golismero plugins查看插件。
  扫描测试golismero scan http://xxx.xxx.xxx.xxx(靶机)



但信息过于杂乱,报告不够规范。

  • nikto.pl

    	nikto -h 靶机ip
    	对多个端口进行扫描命令:Perl nikto.pl -h ip -p port1,port2,port3(如8088443)
    	更新插件和数据库:Perl nikto.pl -update/nikto -h ip -update(此命令需要FQ)
    

扫描速度快且规范。

  • lynis

用于对linux操作系统详细配置等信息进行枚举收集。

  lynis --check-all,enter继续
  实际用lynis --check-all -Q避免交互。



  • unix-privesc-check

    	unix-privesc-check standard 查看linux基本配置、安全相关信息。
    

13.漏洞分析之WEB爬行

针对WEB网站的扫描,需要对网站路径&页面&账户进行枚举/爆破。

  • 首先,查看kali下的字典存放路径/home/usr/share/wordlists,或输入cd /usr/share/wordlists/ls,ls -la

  • apache users

查看apache有哪些账户:

  apache-users -h ip(靶机地址) -l /usr/share/dirbuster/wordlists/appache-user-enum-2.0.txt(用户名字典) -p 80(指定一个端口号) -s 00表示没有ssl支持) -e 403(指定一个返回状态码) -t 10(指定10个线程)
  • cutycapt:网站截图工具

    	CutyCapt --url=http://www.example.org/ --out=localfile.png(生成一个图片名为localfile.png)
    


  • DIRB:强大的目录扫描工具

    	dirb http://172.xxx.xxx.xxx/
    

扫描地址、字典文件、判断根目录文件、进入子目录里进行深度扫描。还有其他使用example,可以终端直接输入dirb查看。

  • dirbuster

终端输入dirbuster,输入目标地址http://xxx.xxx.xxx.xxx,设置字典、线程(视频选择了directory-list-2.3-small.txt),点击start运行。

窗口标签页:扫描目录信息、速度、结果等。

  • VEGA

scan——start new scan——输入目标地址——finish开始扫描。详细了解可以参考这篇博客 Kali Linux Web 渗透测试秘籍 第五章 自动化扫描

  • webslayer

14.漏洞分析之WEB漏洞扫描(一)

  • Cadaver

Cadaver是一个用来浏览和修改WebDAV共享的Unix命令行程序,就像Subversion客户端,它使用了neon的HTTP库。

使用cadaver就像使用命令行的FTP程序,因此它很适合基本的WebDAV调试。它可以以压缩方式上传和下载文件,也会检验属性、拷贝、移动、锁定和解锁文件。

  	cadaver http://xxx.xxx.xxx.xxx/dav/——help——输入这些命令看能否正确执行。

  • davtest

测试对支持webdav的服务器上传文件等。

  davtest -url http://xxx.xxx.xxx.xxx/dav/,查看创建了哪些目录,上传了哪些文件。
  metasploitable下)/var/www/dav$ 目录 ls -la
  • fimap

    	fimap -u 网址 --force-run 查看url、漏洞信息、配置、路径、系统、apache日志等。
    

15.漏洞分析之WEB漏洞扫描(二)

  • JoomlaScanner

类似于Wpscan的扫描器,针对特定CMS。

  • SkipFish

SkipFish是由google出品的一款自动化的网络安全扫描工具,它与Nikto和Nessus等其他开源扫描工具具有相似的功能,但SkipFish是通过HTTP协议处理且占用较低的CPU资源,因此运行速度比较快,每秒钟可以轻松处理2000个请求。

  skipfish -o(output生成文件) 目录(如~/report123) 扫描网址(http://www.baidu.com/)
  ctrl+c结束,生成一个报告index.html




  • Uniscan-gui

是一个有图形界面的扫描工具。勾选扫描options——输入url——start即可扫描。

  • W3AF

w3af是一个Web应用程序攻击和检查框架,该项目已超过130个插件,其中包括检查网站爬虫,SQL注入,跨站(XSS),本地文件包含(LFI),远程文件包含(RFI)等。该项目的目标是要建立一个框架,以寻找和开发web应用安全漏洞,所以很容易使用和扩展。

  命令行下输入 w3af_gui即可打开,有图形界面。输入target——start
  • Wapiti

Wapiti的工作方式与nikto类似,也采用黑盒的方式主动的对被测web应用进行扫描,寻找其中潜在的安全缺陷,但不像nikto提供测试用例库,而是实现了内置的匹配算法。wapiti是由python语言开发的。

  终端wapiti打开
  输入wapiti.py http://www.xxx.com -v 2
  • webshag:集成调用框架

调用Nmap,UScan,信息收集,爬虫(spider)等功能,使扫描过程更易。图形化界面,直接输入target——确定

  • WebSploit

WebSploit是一个开源项目,主要用于远程扫描和分析系统漏洞。

posted @   20179204葛鸽  阅读(459)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
· 一个超经典 WinForm,WPF 卡死问题的终极反思
· ASP.NET Core - 日志记录系统(二)
阅读排行:
· 支付宝事故这事儿,凭什么又是程序员背锅?有没有可能是这样的...
· 在线客服系统 QPS 突破 240/秒,连接数突破 4000,日请求数接近1000万次,.NET 多
· C# 开发工具Visual Studio 介绍
· 在 Windows 10 上实现免密码 SSH 登录
· C#中如何使用异步编程
点击右上角即可分享
微信分享提示