Triple DES Encryption Class

This is a useful encyption class written by Paul Hayman to get started with TripleDES.

Class written in C#

using System;
using System.Collections.Generic;
using System.Text;
using System.Security.Cryptography;
using System.IO;

namespace Security
{
    /// <summary>
    /// Wrapper class for Triple Des encryption
    /// </summary>
    /// <remarks>
    /// Author : Paul Hayman
    /// Date : Feb 2006
    /// info@PaulHayman.com
    /// </remarks>
    public class Encryption
    {

        private TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider();
        private UTF8Encoding utf8 = new UTF8Encoding();

        private byte[] keyValue;
        private byte[] iVValue;

        /// <summary>
        /// Key to use during encryption and decryption
        /// </summary>
        /// <remarks>
        /// <example>
        /// byte[] key = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24 };
        /// </example>
        /// </remarks>
        public byte[] Key
        {
            get { return keyValue; }
            set { keyValue = value; }
        }

        /// <summary>
        /// Initialization vetor to use during encryption and decryption
        /// </summary>
        /// <remarks>
        /// <example>
        /// byte[] iv = { 8, 7, 6, 5, 4, 3, 2, 1 };
        /// </example>
        /// </remarks>
        public byte[] iV
        {
            get { return iVValue; }
            set { iVValue = value; }
        }

        /// <summary>
        /// Constructor, allows the key and initialization vetor to be provided
        /// </summary>
        /// <param name="key"><see cref="Key"/></param>
        /// <param name="iV"><see cref="iV"/></param>
        public Encryption(byte[] key, byte[] iV)
        {
            this.keyValue = key;
            this.iVValue = iV;
        }

        /// <summary>
        /// Decrypt bytes
        /// </summary>
        /// <param name="bytes"></param>
        /// <returns>Decrypted data as bytes</returns>
        public byte[] Decrypt(byte[] bytes)
        {
            return Transform(bytes, des.CreateDecryptor(this.keyValue, this.iVValue));
        }

        /// <summary>
        /// Encrypt bytes
        /// </summary>
        /// <param name="bytes"></param>
        /// <returns>Encrypted data as bytes</returns>
        public byte[] Encrypt(byte[] bytes)
        {
            return Transform(bytes, des.CreateEncryptor(this.keyValue, this.iVValue));
        }

        /// <summary>
        /// Decrypt a string
        /// </summary>
        /// <param name="text"></param>
        /// <returns>Decrypted data as string</returns>
        public string Decrypt(string text)
        {
            byte[] input = Convert.FromBase64String(text);
            byte[] output = Transform(input, des.CreateDecryptor(this.keyValue, this.iVValue));
            return utf8.GetString(output);
        }

        /// <summary>
        /// Encrypt a string
        /// </summary>
        /// <param name="text"></param>
        /// <returns>Encrypted data as string</returns>
        public string Encrypt(string text)
        {
            byte[] input = utf8.GetBytes(text);
            byte[] output = Transform(input, des.CreateEncryptor(this.keyValue, this.iVValue));
            return Convert.ToBase64String(output);
        }

        /// <summary>
        /// Encrypt or Decrypt bytes.
        /// </summary>
        /// <remarks>
        /// This is used by the public methods
        /// </remarks>
        /// <param name="input">Data to be encrypted/decrypted</param>
        /// <param name="cryptoTransform">
        /// <example>des.CreateEncryptor(this.keyValue, this.iVValue)</example>
        /// </param>
        /// <returns>Byte data containing result of opperation</returns>
        private byte[] Transform(byte[] input, ICryptoTransform cryptoTransform)
        {
            // Create the necessary streams
            MemoryStream memory = new MemoryStream();
            CryptoStream stream = new CryptoStream(memory, cryptoTransform, CryptoStreamMode.Write);

            // Transform the bytes as requesed
            stream.Write(input, 0, input.Length);
            stream.FlushFinalBlock();

            // Read the memory stream and convert it back into byte array
            memory.Position = 0;
            byte[] result = new byte[memory.Length];
            memory.Read(result, 0, result.Length);

            // Clean up
            memory.Close();
            stream.Close();

            // Return result
            return result;
        }

    }
}

Class written in VB

Imports System 
Imports System.Collections.Generic 
Imports System.Text 
Imports System.Security.Cryptography 
Imports System.IO 

Namespace Security 
    ''' <summary>
    ''' Wrapper class for Triple Des encryption 
    ''' </summary>
    ''' <remarks> 
    ''' Author : Paul Hayman 
    ''' Date : Feb 2006
    ''' info@PaulHayman.com 
    ''' </remarks>
    Public Class Encryption 
        
        Private des As New TripleDESCryptoServiceProvider() 
        Private utf8 As New UTF8Encoding() 
        
        Private keyValue As Byte() 
        Private iVValue As Byte() 
        
        ''' <summary>
        ''' Key to use during encryption and decryption 
        ''' </summary> 
        ''' <remarks> 
        ''' <example> 
        ''' byte[] key = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24 }; 
        ''' </example>
        ''' </remarks> 
        Public Property Key() As Byte() 
            Get 
                Return keyValue 
            End Get 
            Set 
                keyValue = value 
            End Set 
        End Property 
        
        ''' <summary> 
        ''' Initialization vetor to use during encryption and decryption 
        ''' </summary>
        ''' <remarks> 
        ''' <example> 
        ''' byte[] iv = { 8, 7, 6, 5, 4, 3, 2, 1 }; 
        ''' </example>
        ''' </remarks> 
        Public Property iV() As Byte() 
            Get 
                Return iVValue 
            End Get 
            Set 
                iVValue = value 
            End Set 
        End Property 
        
        ''' <summary> 
        ''' Constructor, allows the key and initialization vetor to be provided 
        ''' </summary>
        ''' <param name="key"><see cref="Key"/></param> 
        ''' <param name="iV"><see cref="iV"/></param>
        Public Sub New(ByVal key As Byte(), ByVal iV As Byte()) 
            Me.keyValue = key 
            Me.iVValue = iV 
        End Sub 
        
        ''' <summary> 
        ''' Decrypt bytes 
        ''' </summary>
        ''' <param name="bytes"></param>
        ''' <returns>Decrypted data as bytes</returns>
        Public Function Decrypt(ByVal bytes As Byte()) As Byte() 
            Return Transform(bytes, des.CreateDecryptor(Me.keyValue, Me.iVValue)) 
        End Function 
        
        ''' <summary> 
        ''' Encrypt bytes 
        ''' </summary> 
        ''' <param name="bytes"></param>
        ''' <returns>Encrypted data as bytes</returns> 
        Public Function Encrypt(ByVal bytes As Byte()) As Byte() 
            Return Transform(bytes, des.CreateEncryptor(Me.keyValue, Me.iVValue)) 
        End Function 
        
        ''' <summary> 
        ''' Decrypt a string 
        ''' </summary> 
        ''' <param name="text"></param>
        ''' <returns>Decrypted data as string</returns>
        Public Function Decrypt(ByVal text As String) As String 
            Dim input As Byte() = Convert.FromBase64String(text) 
            Dim output As Byte() = Transform(input, des.CreateDecryptor(Me.keyValue, Me.iVValue)) 
            Return utf8.GetString(output) 
        End Function 
        
        ''' <summary> 
        ''' Encrypt a string 
        ''' </summary> 
        ''' <param name="text"></param>
        ''' <returns>Encrypted data as string</returns> 
        Public Function Encrypt(ByVal text As String) As String 
            Dim input As Byte() = utf8.GetBytes(text) 
            Dim output As Byte() = Transform(input, des.CreateEncryptor(Me.keyValue, Me.iVValue)) 
            Return Convert.ToBase64String(output) 
        End Function 
        
        ''' <summary> 
        ''' Encrypt or Decrypt bytes. 
        ''' </summary> 
        ''' <remarks> 
        ''' This is used by the public methods 
        ''' </remarks> 
        ''' <param name="input">Data to be encrypted/decrypted</param>
        ''' <param name="cryptoTransform"> 
        ''' <example>des.CreateEncryptor(this.keyValue, this.iVValue)</example> 
        ''' </param> 
        ''' <returns>Byte data containing result of opperation</returns> 
        Private Function Transform(ByVal input As Byte(), ByVal cryptoTransform As ICryptoTransform) As Byte() 
            ' Create the necessary streams 
            Dim memory As New MemoryStream() 
            Dim stream As New CryptoStream(memory, cryptoTransform, CryptoStreamMode.Write) 
            
            ' Transform the bytes as requesed 
            stream.Write(input, 0, input.Length) 
            stream.FlushFinalBlock() 
            
            ' Read the memory stream and convert it back into byte array 
            memory.Position = 0 
            Dim result As Byte() = New Byte(memory.Length - 1) {} 
            memory.Read(result, 0, result.Length) 
            
            ' Clean up 
            memory.Close() 
            stream.Close() 
            
            ' Return result 
            Return result 
        End Function 
        
    End Class 
End Namespace 

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out /  Change )

Facebook photo

You are commenting using your Facebook account. Log Out /  Change )

Connecting to %s