Skip to main content

Encryption in C# Continue

 Encryption in C# Continue

From our previous article Encryption in C#, encryption is the process of translating plain text data (plaintext) into something that appears to be random and meaningless (ciphertext). It is used to transform a data into some un-readable form so that authenticated person only can read/access the data. It requires some secret information to transform the plain text to cipher text; it is usually referred as key.

Decryption is the process of converting ciphertext back to plaintext. To encrypt more than a small amount of data, symmetric encryption is used.

There are many modern cryptographic methods used for encryption and decryption and it is classified in to two classes of key based algorithms.

1.      Symmetric Algorithm

o    Same key is used for both Encryption and Decryption. The key will be kept as secret.

o    Symmetric Ciphers is divided into Stream and Block Ciphers.

§  Stream Ciphers – It encrypts a single bit of plain text at a time.

§  Block Ciphers – It takes number of bits and encrypts them as a single unit.

2.     Asymmetric Algorithm

o    Different key is used for Encryption and Decryption. It is also called as public Key algorithm.

o    Encryption key is public and the Decryption key will be kept as secret.

o    By using this asymmetric algorithm, anyone can encrypt the message by using encryption key but the message can be decrypted only by using decryption key.

3.     Hybrid Encryption – Symmetric and Asymmetric algorithm are used together and it is called as Hybrid Encryption.

Symmetric Encryption Algorithm are as below

  • Data Encryption Standard (DES)
  • Blow Fish
  • Triple DES (3DES)
  • Advanced Encryption Standard (AES)

The code snippets below demonstrate the encryption and decryption using C# programming Language

Encryption

public static string EncryptText(string plainText)

        {

            //Convert the plain text to bytes array

            var plaintextToArray = UTF8Encoding.UTF8.GetBytes(plainText);

            //Instantiate the MD5 cryptor Service provider

            MD5CryptoServiceProvider serviceProvider = new MD5CryptoServiceProvider();

 

            var securityKeyArray = serviceProvider.ComputeHash(UTF8Encoding.UTF8.GetBytes(securityKey));

            //

            serviceProvider.Clear();

            // Data encryption Standard Service Provider

            var desServiceProvider = new TripleDESCryptoServiceProvider

            {

                Key = securityKeyArray,

                Mode = CipherMode.ECB,

                Padding = PaddingMode.PKCS7

            };

          // Create Encryption

            var cryptoTransform = desServiceProvider.CreateEncryptor();

 

            byte[] encrytedArray = cryptoTransform.TransformFinalBlock(plaintextToArray, 0, plaintextToArray.Length);

 

            desServiceProvider.Clear();

 

            return Convert.ToBase64String(encrytedArray, 0, encrytedArray.Length);

        }

 

Decryption

public static string DecryptText(string encryptedText)

        {

            var encryptedTextArray = Convert.FromBase64String(encryptedText);

 

            var cryptoServiceProvider = new MD5CryptoServiceProvider();

 

            var secuKey = cryptoServiceProvider.ComputeHash(UTF8Encoding.UTF8.GetBytes(securityKey));

            //

            cryptoServiceProvider.Clear();

 

            var desTripleCryptoService = new TripleDESCryptoServiceProvider

            {

                Key = secuKey,

                Mode = CipherMode.ECB,

                Padding = PaddingMode.PKCS7

            };

 

            var cryptoTransform = desTripleCryptoService.CreateDecryptor();

 

            var decryptedArray = cryptoTransform.TransformFinalBlock(encryptedTextArray, 0, encryptedTextArray.Length);

            //

            desTripleCryptoService.Clear();

            //

            return UTF8Encoding.UTF8.GetString(decryptedArray);

        }


Thank you

Comments

Post a Comment

Popular posts from this blog

The String.Join Method in C# Explained

The String.Join Method in C#   The string.Join concatenates the elements of a specified array or the members of a collection, using the specified separator between each element or member. Overloads of string.Join Method Description Join(Char, Object[]) Concatenates the string representations of an array of objects, using the specified separator between each member. Join(Char, String[]) Concatenates an array of strings, using the specified separator between each member. Join(String, IEnumerable<String>) Concatenates the members of a constructed IEnumerable<T> collection of type String, using the specified separator between each member. Join(String, Object[]) Concatenates the elements of an object array, using the specified separator between each element. Join(String, String[]) Concatenates all the elements of a string array, usi...

Models in ASP.NET MVC

Models in ASP.NET MVC Explained A model is a class that contains the business logic of your application. It also used for accessing data from the database. The model class does not handle directly input from the browser. In MVC, it is the Controller that handle input from the browser directly and process the request by receiving data from the model and pass it back to view as response. It does not contain any HTML code either. It is a best practice but not mandatory for developers to not have any communications with the view directly, models should only contain a POCO ( Plain Old CLR Objects ) classes. All processing logic and communication with the view should be handled by another layer called Viewmodels. Models are also refers as objects that are used to implement conceptual logic for the application. A controller interacts with the model, access the data, perform the logic and pass that data to the view. Note that it is not mandatory, but it is a good programming...

Classes in C# Explained

C# Class Explained A class is nothing but an encapsulation of properties and methods that are used to represent a real-time entity, as explained by Guru99 . For instance, if you want to work with Guest’s data as in our previous DataDriven Web application . The properties of the Guest would be the Id, GuestName, Address, Phone number etc of the Guest. The methods would include the entry and modification of Guest data. All of these operations can be represented as a class in C# as shown below. using System; namespace CsharpnaijaClassTutorial {     public class Guest     {         public int Id { get ; set ; }         public string GuestName { get ; set ; }         public string Address { get ; set ; }         public string WhomToSee { get ; set ; }     ...