Unit 2 | HTCS 501 Notes | Data Encryption and Compression Notes | AKTU Notes


Symmetric & Asymmetric Key Cryptography

Unit 2 | HTCS 501 Notes | Data Encryption and Compression Notes | AKTU Notes

    Algorithm Types

    Cryptographic algorithms are methods used for encrypting and decrypting data. They are classified into two main types:

    a) Symmetric Key Cryptography

    - What is it?

      - In symmetric cryptography, the same key is used for both encryption and decryption.

    - How does it work?

      - You lock and unlock data with the same password (key).  

      - Both the sender and the receiver must know the secret key.

    - Example:

      - If you encrypt "HELLO" with the key "1234," the same key "1234" is needed to decrypt it back to "HELLO."

    - Advantages:

      - Fast and efficient for large amounts of data.

    - Disadvantages:

      - If someone steals the key, they can read the data

    b) Asymmetric Key Cryptography

    - What is it?

      - In asymmetric cryptography, two different keys are used:  

        1. Public Key: Used for encryption (shared with everyone).  

        2. Private Key: Used for decryption (kept secret).

    - How does it work?

      - The sender uses the public key to encrypt the data, and only the receiver’s private key can decrypt it.

    - Example:

      - If you encrypt a message with your friend’s public key, only your friend can decrypt it using their private key.

    - Advantages:

      - More secure because private keys are never shared.

    - Disadvantages:

      - Slower than symmetric cryptography.


    Modes of Operation

    Modes define how encryption algorithms handle blocks of data. Most algorithms process data in fixed-sized chunks called blocks (e.g., 64 bits or 128 bits).

    a) ECB (Electronic Codebook Mode)

    - How does it work?

      - Each block of plaintext is encrypted independently.

      - The same plaintext block always produces the same ciphertext block.

    - Example:

      - If "HELLO" is divided into blocks and encrypted, repeated blocks (like "LL") produce the same result.

    - Advantages:

      - Simple and fast.

    - Disadvantages:

      - Patterns in the plaintext can show up in the ciphertext, making it less secure.

    - Analogy:

      - Think of writing secret messages but always using the same code for the same word.

    b) CBC (Cipher Block Chaining Mode)

    - How does it work?

      - Each plaintext block is combined with the previous ciphertext block before encryption.

      - An Initialization Vector (IV) is used for the first block to add randomness.

    - Advantages:

      - More secure than ECB because it hides patterns.

    - Disadvantages:

      - Slower than ECB because each block depends on the previous one.

    - Analogy:

      - Like building a chain, where each link depends on the one before it.

    c) CTR (Counter Mode)

    - How does it work?

      - A counter is used to generate a unique block for encryption. Each block is XORed (mathematically combined) with the counter output.

    - Advantages:

      - Fast and can encrypt/decrypt blocks independently (useful for parallel processing).

    - Disadvantages:

      - Requires a unique counter for each block.

    - Analogy:

      - Like numbering pages in a book, where each page gets a unique label.

    d) OFB (Output Feedback Mode)

    - How does it work?

      - Instead of encrypting plaintext directly, it generates a key stream, which is XORed with plaintext to produce ciphertext.

    - Advantages:

      - Good for streaming data.

    - Disadvantages:

      - Errors in one block can affect subsequent blocks.

    - Analogy:

      - Like using a stream of random numbers to encode your message.

    Key Differences Between Symmetric and Asymmetric Algorithms

    Feature Symmetric Key Asymmetric Key
    Key Usage Same key for encryption and decryption Two keys: public and private
    Speed Faster Slower
    Use Case Encrypting large amounts of data Secure communication, digital signatures


    Why Learn Algorithm Types and Modes?

    - Algorithm Types: Understand how data is secured using symmetric and asymmetric keys.  

    - Modes: Learn how encryption algorithms process data securely.


    DES (Data Encryption Standard)

    What is DES?

    - DES is a symmetric key encryption algorithm used to secure data by converting plaintext into ciphertext.

    - It was one of the earliest encryption standards developed by IBM in the 1970s and adopted by the U.S. government.

    How Does DES Work?

    1. Key Size: DES uses a 56-bit key for encryption and decryption.  

    2. Block Size: It encrypts data in fixed-sized blocks of 64 bits.  

    3. Rounds: DES performs 16 rounds of encryption, where data is processed multiple times using substitution and permutation techniques.  

    4. Process:

       - The plaintext is divided into 64-bit blocks.

       - Each block is transformed using the 56-bit key through 16 encryption rounds.

       - After these rounds, ciphertext is produced.

    Advantages:

    - Simple and easy to implement.

    - Was widely used for many years.

    Disadvantages:

    - Outdated: The 56-bit key size is too small for modern computing power, making it vulnerable to brute-force attacks.

    - Not Secure: Advanced techniques can easily crack DES today.

    Use Cases:

    - Previously used for encrypting financial transactions, passwords, and secure communication.

    Real-Life Analogy:

    - Imagine using a lock with a 56-character code to secure your valuables. Initially, it’s strong, but with modern tools, the lock can be broken.


    IDEA (International Data Encryption Algorithm)

    What is IDEA?

    - IDEA is a symmetric key encryption algorithm designed as an improvement over DES.

    - It was developed by James Massey and Xuejia Lai in 1991.

    - IDEA is more secure and uses a larger key size compared to DES.

    How Does IDEA Work?

    1. Key Size: IDEA uses a 128-bit key, making it significantly more secure than DES.  

    2. Block Size: It encrypts data in 64-bit blocks.  

    3. Rounds: IDEA performs 8.5 rounds of encryption, each involving mathematical operations like XOR, addition, and multiplication.  

    4. Process:

       - The plaintext is divided into 64-bit blocks.

       - These blocks are processed through multiple rounds, where substitutions and transformations are applied.

       - At the end of the process, ciphertext is produced.

    Advantages:

    - Strong Security: The 128-bit key size makes it resistant to brute-force attacks.

    - Efficient: Works well in both hardware and software implementations.

    Disadvantages:

    - Computationally Intensive: Requires more processing power than DES.

    - Patent Restrictions: Originally patented, limiting its widespread use in the past.

    Use Cases:

    - Used in secure communication protocols like PGP (Pretty Good Privacy) for email encryption.

    Real-Life Analogy:

    - Imagine upgrading your lock to a high-tech 128-character code. It’s much harder to break, even with modern tools.

    Key Differences Between DES and IDEA

    Feature DES IDEA
    Key Size 56 bits 128 bits
    Block Size 64 bits 64 bits
    Rounds 16 rounds 8.5 rounds
    Security Outdated and vulnerable Strong and secure
    Use Cases Used in legacy systems Used in secure email and data encryption


    Why Learn DES and IDEA?

    - DES: Teaches the foundation of symmetric encryption and its limitations.  

    - IDEA: Shows advancements in cryptography for stronger, more secure algorithms.


    Differential Cryptanalysis

    What is Differential Cryptanalysis?

    - It is a type of cryptographic attack where the attacker studies how differences in plaintexts (input data) affect the differences in ciphertexts (output data).  

    - The goal is to figure out the secret key used in the encryption process by analyzing patterns in these differences.

    How Does It Work?

    1. Plaintext Differences:

       - The attacker selects pairs of plaintexts with slight differences (e.g., only one bit is changed).

    2. Ciphertext Differences:

       - These plaintext pairs are encrypted, and the differences between the resulting ciphertexts are analyzed.

    3. Finding Patterns:

       - Over multiple encryption attempts, patterns in how the differences propagate through the encryption rounds are studied.

    4. Guessing the Key:

       - The attacker uses these patterns to guess parts of the secret key.

    Example:

    - Suppose two plaintexts differ in only one bit. After encryption:

      - Plaintext 1: 1010 → Ciphertext 1: 1110  

      - Plaintext 2: 1011 → Ciphertext 2: 1101  

    - The attacker observes how the one-bit difference in plaintext affects the ciphertext and uses this to learn about the encryption process.

    Why is it Important?

    - It helps cryptographers test the strength of an encryption algorithm.  

    - Algorithms like DES were analyzed with differential cryptanalysis, and improvements were made to resist this attack.

    Advantages for the Attacker:

    - Works well against older ciphers with fewer rounds of encryption.

    Disadvantages:

    - Requires access to multiple plaintext-ciphertext pairs, which may not always be available.


    Linear Cryptanalysis

    What is Linear Cryptanalysis?

    - It is another cryptographic attack where the attacker uses linear approximations to describe the behavior of an encryption algorithm.  

    - The goal is to find relationships between plaintext, ciphertext, and key bits to recover the key.

    How Does It Work?

    1. Linear Relationships:

       - The attacker tries to express certain bits of the plaintext and ciphertext as a linear function (using XOR operations) of key bits.

    2. Collecting Data:

       - A large number of plaintext-ciphertext pairs are needed to check how often the linear relationship holds true.

    3. Finding Probabilities:

       - If a relationship holds true more often than random chance, it helps the attacker guess the key.

    Example:

    - Suppose the attacker guesses that a specific bit in the ciphertext is related to certain bits in the plaintext and key: 

    Finding Probability


      - By checking many plaintext-ciphertext pairs, the attacker calculates probabilities to identify the key.

    Why is it Important?

    - Linear cryptanalysis is a powerful tool to evaluate the security of encryption algorithms.  

    - It helped cryptographers improve algorithms like AES to withstand such attacks.

    Advantages for the Attacker:

    - Requires fewer plaintext-ciphertext pairs compared to differential cryptanalysis.

    Disadvantages:

    - Computationally intensive and may not work well on highly secure algorithms.

    Key Differences Between Differential and Linear Cryptanalysis

    Feature Differential Cryptanalysis Linear Cryptanalysis
    Focus Analyzes differences in plaintext and ciphertext Analyzes linear relationships between bits
    Data Needed Requires a large number of plaintext pairs Requires fewer plaintext-ciphertext pairs
    Type of Attack Based on propagation of differences Based on probability and linear approximations
    Effectiveness Works well on fewer encryption rounds Effective but computationally intensive


    Why Learn These Techniques?

    - Understand Cryptographic Security: These methods help test encryption algorithms for vulnerabilities.  

    - Real-World Applications: Understanding these attacks helps in designing stronger encryption methods.  

    - Engineering Insight: As future engineers, you may work on creating or analyzing cryptographic systems.


    RSA (Rivest-Shamir-Adleman)

    What is RSA?

    - RSA is one of the most widely used asymmetric key encryption algorithms.  

    - It was invented by Ron Rivest, Adi Shamir, and Leonard Adleman in 1977, hence the name "RSA."

    How Does RSA Work?

    1. Key Pair:

       - RSA uses two keys:  

         - Public Key: Used for encryption (shared with everyone).  

         - Private Key: Used for decryption (kept secret).  

    2. Mathematical Foundation:

       - The security of RSA relies on the difficulty of factoring large prime numbers.  

       - Two large prime numbers (p) and (q) are multiplied to create a very large number (n), which forms part of the public key.  

    3. Encryption Process:

       - The sender encrypts the message using the receiver’s public key.  

       - Example:  

    Encryption Process



    4. Decryption Process:

       - The receiver uses their private key to decrypt the ciphertext.  

       - Example: 

    Decryption Process


    Why is RSA Important?

    - RSA enables secure communication without sharing a secret key beforehand.  

    - It’s widely used in digital signatures, secure email, and SSL/TLS for internet security.

    Advantages:

    - High security due to large key sizes (e.g., 2048 bits or more).  

    - No need to share the private key with others.

    Disadvantages:

    - Slower compared to symmetric key algorithms like AES.  

    - Requires significant computational resources.

    Example of RSA in Real Life:

    - Sending a secure email:  

      - The sender encrypts the email using the receiver's public key.  

      - Only the receiver can decrypt the email using their private key.


    Symmetric & Asymmetric Key Together

    Why Combine Symmetric and Asymmetric Key Cryptography?

    - Problem with Symmetric Encryption:  

      - Sharing the same key with everyone is risky. If someone intercepts the key, they can access the data.  

    - Problem with Asymmetric Encryption:  

      - It’s slower and inefficient for encrypting large amounts of data.

    By combining both methods, we can use the strengths of each to achieve both security and efficiency.

    How Do They Work Together?

    Step 1: Generate a Symmetric Key:

       - A random symmetric key (e.g., for AES) is created for encrypting the data.  

       - This key is called the session key because it is only used for one session.

    Step 2: Encrypt the Symmetric Key with RSA:

       - The symmetric key is encrypted using the receiver's public key (asymmetric encryption).  

       - This ensures that only the receiver can decrypt it with their private key.

    Step 3: Use the Symmetric Key for Data Encryption:

       - The large dataset or file is encrypted using the symmetric key (faster encryption).  

       - The encrypted symmetric key is sent along with the ciphertext.

    4. Step 4: Decrypt at the Receiver’s End:

       - The receiver uses their private key to decrypt the symmetric key.  

       - Then, the receiver uses the symmetric key to decrypt the data.

    Example of Combined Use:

    - HTTPS Protocol (Securing Websites):

      - The browser and server use RSA to exchange a symmetric key.  

      - Once exchanged, the symmetric key is used to encrypt all communication (like webpage data).

    Advantages of Combining Both:

    1. Security: Asymmetric encryption secures the key exchange.  

    2. Efficiency: Symmetric encryption ensures fast processing for large data.  

    3. Scalability: Works well in systems like online banking, where security and speed are both crucial.

    Real-Life Analogy:

    1. Symmetric Key Encryption:

       - Like having one key for a house. Both people need the same key to lock and unlock the house.  

       - Problem: If the key is stolen, anyone can access the house.

    2. Asymmetric Key Encryption:

       - Like having a mailbox with a public slot (public key) for everyone to drop letters and a private key to open the mailbox and read the letters.  

       - Problem: Takes more time to process each letter.

    3. Combining Both:

       - The sender writes the letter, locks it in a box (symmetric encryption), and sends the key to unlock the box through a secure channel (asymmetric encryption).


    Digital Signature

    What is a Digital Signature?
    - A digital signature is a cryptographic technique used to verify the authenticity and integrity of a message or document.  
    - It ensures that:
      1. The message comes from the claimed sender (authenticity).  
      2. The message hasn’t been altered during transmission (integrity).  

    How Does a Digital Signature Work?
    1. Key Pair:
       - A pair of keys is used:  
         - Private Key: Used to sign the document.  
         - Public Key: Used to verify the signature.  

    2. Creating the Digital Signature:
       - The sender generates a hash of the message (a short, fixed-size representation of the message).  
       - This hash is encrypted with the sender’s private key to create the digital signature.

    3. Verifying the Digital Signature:
       - The receiver decrypts the signature using the sender’s public key to obtain the hash.  
       - The receiver also generates a hash of the received message.  
       - If the two hashes match, the signature is valid, meaning the message is authentic and hasn’t been tampered with.

    Why Are Digital Signatures Important?
    - Authenticity: Confirms the sender’s identity.  
    - Integrity: Detects any tampering with the message.  
    - Non-repudiation: The sender cannot deny having sent the message because only their private key could create the signature.

    Example:
    - In online banking, digital signatures are used to verify that transaction requests genuinely come from the customer.

    Advantages:
    - Provides strong security for online communication.  
    - Widely used in secure email, software distribution, and online payments.

    Disadvantages:
    - Relies on the security of the private key. If the private key is compromised, the system is vulnerable.  


    Knapsack Algorithm

    What is the Knapsack Algorithm?
    - The Knapsack algorithm is one of the earliest public key cryptographic systems, inspired by the mathematical knapsack problem.  
    - It involves solving complex problems related to finding subsets of numbers that sum up to a particular value, which is computationally hard.

    How Does the Knapsack Algorithm Work?
    1. Key Generation:
       - A super-increasing sequence (a set of numbers where each number is greater than the sum of all previous numbers) is created.  
       - A public key is derived from this sequence using a transformation involving modular arithmetic and a multiplier.  
       - The public key is shared, while the original sequence and transformation parameters are kept secret as the private key.

    2. Encryption:
       - The plaintext message is converted into a binary sequence.  
       - Each bit of the binary sequence is multiplied by the corresponding number in the public key.  
       - The resulting values are summed up to create the ciphertext.

    3. Decryption:
       - The receiver uses the private key to reverse the transformation and solve the knapsack problem, recovering the original binary sequence and, ultimately, the plaintext message.

    Why Was the Knapsack Algorithm Important?
    - It was one of the first public key cryptosystems and introduced the concept of encryption based on hard mathematical problems.  

    Advantages:
    - Simple to implement.  
    - Uses basic arithmetic operations.

    Disadvantages:
    - The original version of the algorithm was broken using advanced mathematical attacks.  
    - It is no longer considered secure for modern cryptographic use.

    Example:
    - Suppose the private key is a sequence: {1, 2, 4, 10, 20}, and the public key is derived from it.  
    - To encrypt the message "10101", the ciphertext is calculated by summing:  
     1 x 1 + 2 x 0 + 4 x 1 + 10 x 0 + 20 x 1 = 25.  
    - To decrypt, the receiver solves the equation to find the binary sequence.

    Key Differences Between Digital Signature and Knapsack Algorithm

    Feature Digital Signature Knapsack Algorithm
    Purpose Verifies authenticity and integrity of data Encrypts data based on mathematical problems
    Type Cryptographic tool for verification Public key cryptographic system
    Current Usage Widely used in modern security systems Obsolete due to vulnerabilities

        

    No comments:

    Post a Comment