using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;
namespace Vinno.vCloud.Common.License.Licenses
{
public static class AesHelper
{
///
/// "Vinno.vCloud.CurrentLicense" two MD5
///
private const string Key = "2A4A2B05EFD02D5BDEBB55711213BBBD";
///
/// Gets Encrypt text
///
///
///
public static string Encrypt(string inputText)
{
return AesEncrypt(inputText, Key);
}
///
/// Gets Decrypt text
///
///
///
internal static string Decrypt(string inputText)
{
return AesDecrypt(inputText, Key);
}
///
/// AES algorithm Encrypt string
///
///
/// AES Key
///
private static string AesEncrypt(string input, string key)
{
var encryptKey = Encoding.UTF8.GetBytes(key);
using (var aesAlg = Aes.Create())
{
using (var encryptor = aesAlg.CreateEncryptor(encryptKey, aesAlg.IV))
{
using (var msEncrypt = new MemoryStream())
{
using (var csEncrypt = new CryptoStream(msEncrypt, encryptor,
CryptoStreamMode.Write))
using (var swEncrypt = new StreamWriter(csEncrypt))
{
swEncrypt.Write(input);
}
var iv = aesAlg.IV;
var decryptedContent = msEncrypt.ToArray();
var result = new byte[iv.Length + decryptedContent.Length];
Buffer.BlockCopy(iv, 0, result, 0, iv.Length);
Buffer.BlockCopy(decryptedContent, 0, result,
iv.Length, decryptedContent.Length);
return Convert.ToBase64String(result);
}
}
}
}
///
/// AES algorithm Decrypt string
///
///
/// AES Key
///
private static string AesDecrypt(string cipherText, string keyString)
{
var fullCipher = Convert.FromBase64String(cipherText);
byte[] iv = new byte[16];
var cipher = new byte[fullCipher.Length - iv.Length];
Buffer.BlockCopy(fullCipher, 0, iv, 0, iv.Length);
Buffer.BlockCopy(fullCipher, iv.Length, cipher, 0, fullCipher.Length - iv.Length);
var key = Encoding.UTF8.GetBytes(keyString);
using (var aesAlg = Aes.Create())
{
using (var decryptor = aesAlg.CreateDecryptor(key, iv))
{
string result;
using (var msDecrypt = new MemoryStream(cipher))
{
using (var csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read))
{
using (var srDecrypt = new StreamReader(csDecrypt))
{
result = srDecrypt.ReadToEnd();
}
}
}
return result;
}
}
}
}
}