data:image/s3,"s3://crabby-images/6701a/6701a689455294e4c49944fbc0e886d975a4d65a" alt="Wireshark https traffic"
We will now try the 3 available Follow Streams commands: Remark that for packets 9 and 10, the Protocol column value changed from TLSv1.2 to HTTP, and the Info column from Application Data to HTTP methods and replies.Īnd in the bottom view (hexadecimal & ASCII dump), a “Decrypted TLS” tab was added: When you then close the dialogs, and the main screen regains focus, the TLS data will be decrypted: Search for the TLS protocol, and edit the RSA Keys list. This pre-master secret is encrypted with the public RSA key of the server. That’s because in this example, Wireshark needs to decrypt the pre-master secret sent by the client to the server. If we inspect that handshake, more precisely, looking at the Server Hello packet, we see that a cipher suite was selected that relies on RSA and AES:ĭata encrypted with this cipher suite can be decrypted by Wireshark when we provide the private RSA key of the server.
data:image/s3,"s3://crabby-images/d3953/d3953ec35b7e78b3a101e06c03719173a3619608" alt="wireshark https traffic wireshark https traffic"
Here is a screenshot of the packet capture for this HTTPS traffic:įollowing the TCP stream shows that the data is encrypted (except for some parts during the handshake, like the certificate): I choose the other options to produce as much information as possible: downloaded content (01.data), headers (01.headers) and a trace file (01.trace). Option –insecure is necessary because I’m using a self-signed certificate.
data:image/s3,"s3://crabby-images/b2777/b2777ef7d724344e29f6299082330fd98e464ee1" alt="wireshark https traffic wireshark https traffic"
data:image/s3,"s3://crabby-images/99f89/99f89b32ceaa896f292c9bd65e7d3791a48e7138" alt="wireshark https traffic wireshark https traffic"
To force a cipher suite that is based on RSA for the exchange of the pre-master secret, I use options –tls-max 1.2 and –ciphers AES256-SHA. I use the following curl command with options to force a TLS encryption method that is based on a pre-master secret that is encrypted with the public RSA key of the server:Ĭurl.exe –verbose –insecure –tls-max 1.2 –ciphers AES256-SHA –dump-header 01.headers –output 01.data –trace 01.trace –trace-time I use curl for Windows build with OpenSSL, and not the curl version distributed with Windows 10, that relies on schannel. I use my TCP honeypot to set up a web server, and curl to request a page over TLS. Remark that this method will not work with modern browsers and web servers, as they use perfect forward secrecy. This master secret is derived from a pre-master secret, which is securely exchanged between the client and server using RSA crypto. I made my example as such, that the encryption in this example is done with keys derived from a master secret.
data:image/s3,"s3://crabby-images/89024/89024daf69d11b50e72989491090eb1a84e86ba8" alt="wireshark https traffic wireshark https traffic"
In this first example, I show how to decrypt a TLS stream with Wireshark.
data:image/s3,"s3://crabby-images/6701a/6701a689455294e4c49944fbc0e886d975a4d65a" alt="Wireshark https traffic"