22-12-20-Encrypto-Wireshark
Some traffic packets may be encrypted. When I import the private key in one case, I can’t get the decrypted packets like http.
FinalIy, I search for this problem and get the solution.
This post aims to make a conclusion about the encrypted-traffic-packets(tls/ssl)
.
REFERENCE
Really thank for the article!
The second is to edit the configuration of computer, which can be caught in the direct way by using webshell.
DECRYPT TLS/SSL
There are three methods to decrypt the encrypted-ssl/tls packets.
- Use the
server's cert
or theprivate-key
to decrypt. - Use the
ssl-key-log-file
to decrypt. - Disable the config setting to decrypt packets which use the
Diffie-Hellman-Exchange
.
Server’s cert/Private-key
preparation
- TLS/SSL packets
- cert or private-key
- wireshark
notice
The TLS/SSL packets should not relate to the Diffie-Hellman-Exchange
and just a common encrypted packets.
CERT/PRIVATEKEY
The cert or private-key should not be encrypted. And usually, the private-key is the standard of PKCS#8
.
If you have a binary DER, it cannot be used in wireshark, and we ought to make a convert.
1 | openssl pkcs8 -nocrypt -in der.key -informat DER -out pem.key -outformat PEM |
- der.key: the name and root of DER
- pem.key: the output file
And, the private-key ought to be like this:
data:image/s3,"s3://crabby-images/230c3/230c35068b71de39e858cfb20ec7bcc0768c7bbe" alt="Private-key"
which shows that the beginning is -----BEGIN RSA PRIVATE KEY-----
.
DECRYPT KEY
If the beginning is -----BEGIN ENCRYPTED PRIVATE KEY-----
, we should decrypt the key in a proper way.
a common command is:
1 | openssl rsa -in [source file] -out [outfile] |
step
- OPEN the wireshark and import the private-key or cert.
data:image/s3,"s3://crabby-images/bafef/bafef11dfcf7cf0eb2baf85a5981d55d3a959cde" alt="setting"
- RSA keys list. Import private key, add the
port
,ip
,protocol
,root
and the chosenpassword
. Mainly used. - TLS debug file. Some debug file.
- Master-Secret log. Key log file.
- If all things right, and we will see the
http traffic
.
Key log file
Use the key log file
. Usually, this file is in the traffic packets. The key log file is like this.
data:image/s3,"s3://crabby-images/52813/528131841d9a6343a3d6192ff7f72ac76400f513" alt="key log file"
Relate to D-H
Sometimes, the encrypted traffic packets cannot be decrypted by using methods above.
how to recognize
When we analyze the traffic packets, we use command like ip.addr == xxx.xxx.xxx.xxx && tls
to find the target packets.
If we see the Client Hello
, we should make a notice that it maybe a D-H encrypted traffic packet
.
For example:
data:image/s3,"s3://crabby-images/cc230/cc2308d4735882f18e19ca6ada7bd03e2b6308fa" alt="D-H encrypted"
We can change the browser to catch the traffic again.
set the firefox
The address is about:config
, and search for the dhe
.
We can change the target according to the traffic packets or make all things false
.
data:image/s3,"s3://crabby-images/d2f3f/d2f3f70cea3c9e7ba8227420d50e2515c5ec880b" alt="change firefox setting"
recatch the traffic and analyze
data:image/s3,"s3://crabby-images/ce30e/ce30edf4a98ade7f285e31711931436a6b96ea44" alt="remove dhe"
After importing the private key, we can see the decryptedhttp traffic
.
data:image/s3,"s3://crabby-images/104ad/104ad35cb4b0f6157116ebfe40562a087a19c7c9" alt="decrypted http traffic"
CONCLUSION
The Diffie-Hellman-Exchange
is really beyond my imagination.