When you visit a website that doesn’t use HTTPS, your browser will show a warning. This is because, without HTTPS, the data exchanged between your browser and the website’s server is not encrypted. This means that sensitive information like passwords or credit card numbers can be intercepted and read by anyone who manages to capture the data.
How TLS Works:
- Establishing a Connection:
- Initially, similar to HTTP, the browser establishes a TCP connection with the server.
- TLS Handshake:
- The process begins with the browser sending a “client hello” message to the server. This message includes information about the TLS versions the browser supports (such as TLS 1.2, TLS 1.3, etc.) and the cipher suites it can use (a cipher suite is a set of encryption algorithms used to encrypt the data).
- Server Responds:
- The server responds with a “server hello” message. This message includes the TLS version and the cipher suite that the server has chosen from the list provided by the browser. The server also sends its digital certificate, which contains the server’s public key and is signed by a trusted certificate authority (CA).
- Certificate Verification:
- The browser verifies the server’s digital certificate. It checks if the certificate is valid, has not expired, and is signed by a trusted CA. This step ensures that the server is authentic and trusted.
- Key Exchange:
- The browser and the server use the server’s public key to securely exchange a pre-master secret. This pre-master secret will be used to generate the session keys. For forward secrecy, modern implementations use Diffie-Hellman key exchange algorithms.
- Generating Session Keys:
- Both the browser and the server independently generate session keys from the pre-master secret. These session keys are symmetric keys used for encrypting and decrypting the data exchanged during the session.
- Finishing the Handshake:
- The browser sends a “finished” message, encrypted with the session key, to the server. The server decrypts the message and, if it is correct, sends its own “finished” message encrypted with the session key.
- Secure Communication Established:
- After the handshake is successfully completed, the browser and the server start using the session keys to encrypt and decrypt the data they exchange. This ensures that all data transmitted between the browser and the server is secure and unreadable to anyone who might intercept it
How SSL Works:
Steps of how SSL (Secure Sockets Layer) works, formatted similarly to the TLS steps:
- Establishing a Connection:
- The browser establishes a TCP connection with the server.
- Client Hello:
- The browser sends a “client hello” message to the server, which includes supported SSL versions and cipher suites.
- Server Hello:
- The server responds with a “server hello” message, indicating the chosen SSL version and cipher suite, and sends its digital certificate.
- Certificate Verification:
- The browser verifies the server’s digital certificate, ensuring it is valid, not expired, and signed by a trusted Certificate Authority (CA).
- Key Exchange:
- The browser and server use the server’s public key to securely exchange a pre-master secret. In SSL, the key exchange typically uses RSA.
- Generating Session Keys:
- Both the browser and the server generate session keys from the pre-master secret. These session keys are used for symmetric encryption during the session.
- Finished Messages:
- The browser sends a “finished” message, encrypted with the session key, to the server. The server decrypts it and, if correct, sends its own “finished” message encrypted with the session key.
- Secure Communication:
- The browser and server now use the session keys to encrypt and decrypt all data exchanged, ensuring secure communication.
Leave a Reply