DEV Community

Ajay Kumar
Ajay Kumar

Posted on

Symmetric Encryption With C# Coding Example: A Comprehensive Guide

In the world of cybersecurity, encryption is a vital technique used to secure sensitive information. Symmetric encryption is one of the fundamental methods where the same key is used for both encryption and decryption of the data. In this blog post, we will explore symmetric encryption and provide a step-by-step C# coding example to demonstrate how to implement it.

Understanding Symmetric Encryption

Symmetric encryption algorithms use the same key for both encryption and decryption processes. This means that the sender and the receiver must both know and use the same secret key. Since the same key is used for both operations, symmetric encryption is generally faster and more efficient than asymmetric encryption, where different keys are used for encryption and decryption.

Implementing Symmetric Encryption in C

Let's implement symmetric encryption in C# using the Advanced Encryption Standard (AES) algorithm, which is a widely used symmetric encryption algorithm. Follow these steps to create a simple C# console application for symmetric encryption:

Step 1: Set Up Your C# Project
Create a new C# console application in Visual Studio or any other C# IDE of your choice.

Step 2: Add System.Security.Cryptography Namespace
Ensure you include the System.Security.Cryptography namespace in your C# file. This namespace provides classes for various cryptographic operations, including symmetric encryption.

using System;
using System.IO;
using System.Security.Cryptography;

Enter fullscreen mode Exit fullscreen mode

Step 3: Generate a Symmetric Key and IV (Initialization Vector)
In symmetric encryption, both the key and IV need to be shared between the sender and receiver. The IV adds an extra layer of security by ensuring that the same plaintext encrypted with the same key will produce different ciphertexts.

// Generate a random key and IV
byte[] key = new byte[32]; // 256 bits
byte[] iv = new byte[16]; // 128 bits

using (var rng = new RNGCryptoServiceProvider())
{
    rng.GetBytes(key);
    rng.GetBytes(iv);
}

Enter fullscreen mode Exit fullscreen mode

Step 4: Encrypt and Decrypt Data
Now, let's create methods to encrypt and decrypt data using the generated key and IV.

public static byte[] Encrypt(string plainText, byte[] key, byte[] iv)
{
    using (Aes aesAlg = Aes.Create())
    {
        aesAlg.Key = key;
        aesAlg.IV = iv;

        // Create an encryptor to perform the stream transform
        ICryptoTransform encryptor = aesAlg.CreateEncryptor(aesAlg.Key, aesAlg.IV);

        // Create the streams used for encryption
        using (MemoryStream msEncrypt = new MemoryStream())
        {
            using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
            {
                using (StreamWriter swEncrypt = new StreamWriter(csEncrypt))
                {
                    // Write all data to the stream
                    swEncrypt.Write(plainText);
                }
            }
            return msEncrypt.ToArray();
        }
    }
}

public static string Decrypt(byte[] cipherText, byte[] key, byte[] iv)
{
    using (Aes aesAlg = Aes.Create())
    {
        aesAlg.Key = key;
        aesAlg.IV = iv;

        // Create a decryptor to perform the stream transform
        ICryptoTransform decryptor = aesAlg.CreateDecryptor(aesAlg.Key, aesAlg.IV);

        // Create the streams used for decryption
        using (MemoryStream msDecrypt = new MemoryStream(cipherText))
        {
            using (CryptoStream csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read))
            {
                using (StreamReader srDecrypt = new StreamReader(csDecrypt))
                {
                    // Read the decrypted bytes from the decrypting stream
                    return srDecrypt.ReadToEnd();
                }
            }
        }
    }
}

Enter fullscreen mode Exit fullscreen mode

Step 5: Test the Encryption and Decryption
Now, you can test the encryption and decryption methods by calling them with a sample string:

static void Main(string[] args)
{
    string originalText = "Hello, Symmetric Encryption!";
    byte[] encryptedBytes = Encrypt(originalText, key, iv);
    string decryptedText = Decrypt(encryptedBytes, key, iv);

    Console.WriteLine("Original Text: " + originalText);
    Console.WriteLine("Encrypted Text: " + Convert.ToBase64String(encryptedBytes));
    Console.WriteLine("Decrypted Text: " + decryptedText);
}

Enter fullscreen mode Exit fullscreen mode

Run your program, and you should see the original, encrypted, and decrypted texts printed in the console.

Congratulations! You have successfully implemented symmetric encryption in C# using the AES algorithm. Remember that in a real-world scenario, you need to securely share the key and IV between the communicating parties to ensure secure communication.

This example provides a basic understanding of symmetric encryption in C#. You can further explore different symmetric encryption algorithms and modes, as well as

Top comments (0)