Decrypting Encryption: Simplifying a Complex Topic
data:image/s3,"s3://crabby-images/b711f/b711f7b9dddd42fca63f0b0617f9965f45360f8e" alt="Sharon Jonallagadda"
data:image/s3,"s3://crabby-images/38467/38467e0e30e1c4dd95cf56f087e967d1eb5b46f1" alt=""
Before understanding about the encryption, let me first talk about confidentiality, integrity, authenticity and non -repudiation.
Confidentiality is making sure the information is protected and only authorized persons can view the information.
Integrity is making sure that the information is not changed and we would know if the information is changed using hashing.
Authenticity is knowing who sent or created the information.
Non repudiation is making sure that the persons involved in communicating information digitally don't deny the actions at a later point of time.
Okay let's talk about encryption now.
What is encryption? It is a method used to change the plaintext data to unreadable data and which can only be read once it is decrypted.
Types of encryption? One is asymmetric and the other is symmetric encryption.
In Symmetric encryption you use only one key to encrypt and decrypt the data.
Example : When A wants to send a message to B then A and B will use a key that both of them agreed upon to use. So, A encrypts the message using the shared key and sends it to B and B can decrypt the message using the same key.
In this the main problem is the exchange of shared key. It can only be shared using a secured channel. And if any hacker hacks the channel, will be able to get the shared key and can decrypt the message. To overcome this, the asymmetric encryption came into picture.
Asymmetric encryption is the one in which you have two keys which is public and private key for encryption and decryption.
Example: When A wants to send a message to B then A will encrypt the message using B's public key and sends it to B. B then decrypts it using B's private key.
This way we can make sure that confidentiality is achieved. Asymmetric encryption will only ensure confidentiality. It will ensure integrity using hashing and digital signatures.
However, how can B be sure that the message he received is from A and not anyone else? Here comes the digital signatures into picture. Digital signatures will be helpful in identifying who the sender is.
Taking the same example as above, A needs to send a message to B. A will generate a hash for his message and encrypts the hash using his private key and here we need to note that the message is not encrypted, it is sent as a plain text only along with the digital signature. Now the plain text along with the digital signature is sent to B. B will now decrypt the digital signature with A's public key. This way, B can be sure that the message was sent by A only because he is able to decrypt the digital signature using A's public key and if the hash matches then B can be sure of integrity as well.
Through this we can also achieve non repudiation because A cannot deny that the message is not sent by him because the message can be decrypted using his public key only.
However, while asymmetric encryption provides strong security, it has limitations. It's slow due to complex mathematical operations, and there’s a size limit on the data it can handle efficiently, typically around 250 bytes. This is why asymmetric encryption is mainly used to exchange a symmetric key, which is then used for encrypting larger volumes of data.
But if we notice one point here, through the digital signatures confidentiality cannot be achieved because the message here is sent in a plain text format only and not encrypted and the digital signature can be decrypted using A's public key which is easily available publicly. So in that case if we want to achieve confidentiality, integrity and authenticity then we need to use something called hybrid encryption were we can use both the symmetric and asymmetric encryption.
Before going ahead with hybrid encryption, let us know how keys are exchanged in symmetric encryption in a secured way and that is were these mathematical algorithms come into picture which is Diffie-Hellman Key Exchange and Elliptic Curve Diffie-Hellman using which we can derive a shared key share by combining senders private key with the receiver's public key and generate a shared key. Mostly DHKEY method is mostly followed for key exchange which uses modular exponentiation method to generate a shared key.
Hybrid Encryption: In this the asymmetric encryption is used for the exchange of symmetric keys and symmetric encryption is used for encrypting the actual message. So, what happens here is that sender A will generate a random symmetric key and uses this to encrypt the message. Then, A uses B's public key to encrypt the randomly generated symmetric key and the encrypted message and the encrypted symmetric key to B. B now decrypts the symmetric key using B's private key and using the symmetric key B will decrypt the encrypted message.
Only in this encryption is that the random symmetric key is generated which is encrypted using the receiver's public key and is used to encrypt the message. Receiver will use the private key to decrypt the symmetric key encryption and use the symmetric key to decrypt the encrypted message.
Subscribe to my newsletter
Read articles from Sharon Jonallagadda directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by
data:image/s3,"s3://crabby-images/b711f/b711f7b9dddd42fca63f0b0617f9965f45360f8e" alt="Sharon Jonallagadda"
Sharon Jonallagadda
Sharon Jonallagadda
Pursuing my Master’s in IT. Documenting my journey as I work towards securing an internship and a full-time role. Sharing the knowledge and experiences I gain along the way.