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; } } } } }