为何Wireshark没法解密HTTPS数据

TLS握手整个过程linux

在解决这个问题以前,先总体了解一下TLS的握手全过程。省略了不常见的过程。如图:web


为何Wireshark没法解密HTTPS数据为何Wireshark没法解密HTTPS数据
下面按顺序介绍各握手步骤。算法

Client Hellochrome

这是TLS握手的第一步,由客户端发起请求。此协议主要包括了一个客户端生成的随机字符串(用来下面生成session key),还有客户端支持的加密套件列表。如图:服务器


为何Wireshark没法解密HTTPS数据为何Wireshark没法解密HTTPS数据

Server Hello网络

服务器收到客户端的Client Hello数据包以后,根据客户端发来的加密套件列表,选择一个加密套件,也生成一个随机字符串返回给客户端。咱们看到下图中的加密套件为,密钥交换算法使用ECDHE_RSA,对称加密算法使用AES_256_GCM_SHA384,如图:session


为何Wireshark没法解密HTTPS数据为何Wireshark没法解密HTTPS数据

Server Certificate加密

Server Key Exchange协议包,由服务器返回,主要目的是与客户端交换用于数据对称加密的密钥。如图firefox


为何Wireshark没法解密HTTPS数据为何Wireshark没法解密HTTPS数据

Server Hello Done教程

服务器返回此协议数据,告诉客户端已经完成返回所需用于密钥交换的数据。服务器等待客户端响应。

Client Key Exchange

客户端根据服务器返回的DH密钥数据生成DH公共数据也发给服务器,用来生成最终的pre-master-secret。如图:


为何Wireshark没法解密HTTPS数据为何Wireshark没法解密HTTPS数据

Change Cipher Spec

此协议用于客户端和服务器相互告知也完成密钥交换过程,能够切换到对称加密过程。
到这里大概的TLS握手过程就结束了。为解决本文中的问题,还须要了解密钥交换的算法,RSA和Diffie–Hellman。

密钥交换算法

密钥交换算法目前经常使用的有RSA和Diffie-Hellman。
对于密钥交换使用RSA算法,pre-master-secret由客户端生成,并使用公钥加密传输给服务器。
对于密钥交换使用Diffie-Hellman算法,pre-master-secret则经过在Key Exchange阶段交换的信息,由各自计算出pre-master-secret。因此pre-master-secret没有存到硬盘,也没有在网络上传输,wireshark就没法获取session key,也就没法解密应用数据。那咱们是否能够反向计算出pre-master-secret呢?理论上能够,可是很是困难。
对Diffie-Hellman算法感兴趣的能够参考https://en.wikipedia.org/wiki/Diffie%E2%80%93Hellman_key_exchange

解决方法

说了这么多,究竟有什么办法可让wireshark解密数据?咱们能够经过下面几种方法来使wireshark能解密https数据包。
1. 中间人攻击;
2. 设置web服务器使用RSA做为交换密钥算法;
3. 若是是用chrome,firefox,能够设置导出pre-master-secret log,而后wireshark设置pre-master-secret log路径,这样就能够解密了。

免费提供最新Linux技术教程书籍,为开源技术爱好者努力作得更多更好:http://www.linuxprobe.com/

相关文章
相关标签/搜索