Wireshark基础使用,SSL解密及http抓包入门教程


  • Wireshark VS Fiddler/Charles
  • (一)下载与安装
  • (二)抓取https等解密
  • (三)报文传输各层简要介绍

Wireshark VS Fiddler/Charles

Wireshark功能很多、作用效果很底层,并且可以监听指定的网卡上流过的所有流量,支持的协议如下:

ARP 协议:地址解析协议,即ARP(Address Resolution Protocol),是根据 IP地址 获取 物理地址 的一个 TCP/IP协议

ICMP 协议:控制 报文 协议。 它是 TCP/IP协议簇 的一个子协议,用于在IP 主机 、 路由 器之间传递控制消息

TCP 协议, TCP/IP是一种面向连接的、可靠的、基于字节流的传输层通信协议,它会保证数据不丢包、不乱序。TCP全名是Transmission Control Protocol,它是位于网络OSI模型中的第四层(Transport layer)

图片[1] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

三次握手:

理想状态下,TCP连接一旦建立,在通信双方中的任何一方主动关闭连 接之前,TCP 连接都将被一直保持下去。断开连接时服务器和客户端均可以主动发起断开TCP连接的请求,断开过程需要经过“四次握手”(过程就不细写 了,就是服务器和客户端交互,最终确定断开)

通俗的话:三次握手是 1.客户端发生请求,“服务器服务器,请求请求!!!” 2.服务器不确定是不是他,要进行确认,“我不知道你是不是我要等的那个客户端,我要确定一下” 3.客户端就发送确认信息,“是我是我!” 服务器收到之后,确认过眼神遇上对的客户端,就建立连接了。

UDP 协议:UDP协议与TCP协议一样用于处理数据包,在OSI模型中,两者都位于传输层,处于IP协议的上一层。UDP有不提供数据包分组、组装和不能对数据包进行排序的缺点,也就是说,当报文发送之后,是无法得知其是否安全完整到达的

DNS 协议:DNS协议是用来将域名转换为IP地址(也可以将IP地址转换为相应的域名地址)

HTTP 协议, FTP 协议:略

Fidder 的强大在于,专门为 Http/Https 协议定制的软件,主要为了抓取这两个协议的数据包

(一)下载与安装

https://www.wireshark.org/download.html

图片[2] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

Win补丁下载:

http://www.win10pcap.org/download/

图片[3] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

执行需要抓包的操作,如ping www.baidu.com

图片[4] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

该图为 Wireshark 的主界面,界面中显示了当前可使用的接口,例如,本地连接 5、本地连接 10 等。要想捕获数据包,必须选择一个接口,表示捕获该接口上的数据包

图片[5] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

操作完成后相关数据包就抓取到了。为避免其他无用的数据包影响分析,可以通过在过滤栏设置过滤条件进行数据包列表过滤,获取结果如下。说明:ip.addr == 110.242.68.4 and icmp 表示只显示ICPM协议且源主机IP或者目的主机IP为110.242.68.4 的数据包。

图片[6] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

http条件过滤

图片[7] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

IP 过滤 比如 ip.src ==192.168.1.102 显示源地址为192.168.1.102, ip.dst==192.168.1.102, 目标地址为192.168.1.102

Http模式过滤 http.request.method==”GET”, 只显示HTTP GET方法的

**http.host==**53zaixian.com

http.host contains 53zaixian.com

图片[8] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

过滤抓取53域名的http请求

http.host contains 53zaixian.com

图片[9] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

(二)抓取https等解密

Wireshark+Chrome,HTTPS数据包抓取配置

配置系统环境变量

变量名:SSLKEYLOGFILE 变量值:此处可以随意指定,作用是告诉chrome输出SSLKEY的位置,而wireshark则可以使用此文件来解密HTTPS数据包。

图片[10] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

配置Wireshark

填入刚才在系统变量指定的keylog文件的存储路径,以便wireshark访问keylog中的key,来解密HTTPS数据包。 中文:编辑>首选项>protocols>TLS English:Edit>Preferences>protocols>TLS

图片[11] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

(三)报文传输各层简要介绍

·Frame: 物理层的数据帧概况

·Ethernet II: 数据链路层以太网帧头部信息

·Internet Protocol Version 4: 互联网层IP包头部信息

·Transmission Control Protocol: 传输层T的数据段头部信息,此处是TCP

·Hypertext Transfer Protocol: 应用层的信息,此处是HTTP协议

物理层数据帧

图片[12] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

数据链路层以太网帧的头部信息

图片[13] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

网络层IP头部包信息

图片[14] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

传输层数据包头部信息

图片[15] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

HTTP协议分析,请求报头,报文分析:

图片[16] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

响应报文

图片[17] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

追踪流查看详细信息:

这样就可以比较清晰的看到一个数据流过程。还可以看到自己的cookie,host,浏览器信息,等http数据包的详细内容。

图片[18] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL
图片[19] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL
图片[20] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL
图片[21] - Wireshark基础使用,SSL解密及http抓包入门教程 - MaxSSL

本文由 mdnice 多平台发布

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享