码迷,mamicode.com
首页 > 其他好文 > 详细

C# AES,AesManaged使用学习

时间:2014-08-11 23:48:03      阅读:480      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   使用   os   io   for   

加密

static byte[] EncryptBytes_Aes(byte[] plainText, byte[] Key, byte[] IV)
        {
            // Check arguments.
            if (plainText == null || plainText.Length <= 0)
                throw new ArgumentNullException("plainText");
            if (Key == null || Key.Length <= 0)
                throw new ArgumentNullException("Key");
            if (IV == null || IV.Length <= 0)
                throw new ArgumentNullException("IV");
            byte[] encrypted;
            // Create an AesManaged object
            // with the specified key and IV.
            using (AesManaged aesAlg = new AesManaged())
            {
                aesAlg.Key = Key;
                aesAlg.IV = IV;

                // Create a decrytor 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 (BinaryWriter bw = new BinaryWriter(csEncrypt))
                        {
                            bw.Write(plainText);
                        }
                    }
                    encrypted = msEncrypt.ToArray();
                }
            }

            // Return the encrypted bytes from the memory stream.
            return encrypted;
        }

解密

static byte[] DecryptBytes_Aes(byte[] cipherText, byte[] Key, byte[] IV)
        {
            // Check arguments.
            if (cipherText == null || cipherText.Length <= 0)
                throw new ArgumentNullException("cipherText");
            if (Key == null || Key.Length <= 0)
                throw new ArgumentNullException("Key");
            if (IV == null || IV.Length <= 0)
                throw new ArgumentNullException("IV");

            // Declare the string used to hold
            // the decrypted text.
            List<byte> plaintext = new List<byte>();

            // Create an AesManaged object
            // with the specified key and IV.
            using (AesManaged aesAlg = new AesManaged())
            {
                aesAlg.Key = Key;
                aesAlg.IV = IV;

                // Create a decrytor 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 (BinaryReader br = new BinaryReader(csDecrypt))
                        {
                            int bufferLen = 1024;
                            byte[] buffer = new byte[bufferLen];
                            int read = 0;
                            while ((read = br.Read(buffer, 0, bufferLen)) > 0)
                                plaintext.AddRange(buffer.Take(read));
                        }
                    }
                }

            }

            return plaintext.ToArray();
        }

演示:

string str = "Test ase,我们一起来测试AES";
            byte[] plainBytes = Encoding.UTF8.GetBytes(str);
            using (AesManaged aes = new AesManaged())
            {
                byte[] eBytes = EncryptBytes_Aes(plainBytes, aes.Key, aes.IV);
                byte[] dBytes = DecryptBytes_Aes(eBytes, aes.Key, aes.IV);

                //OutputBytes(plainBytes);
                //OutputBytes(eBytes);
                //OutputBytes(dBytes);
                
                Console.WriteLine("明文:{0}", str);
                Console.WriteLine("明文数组:{0}", FormatBytes(plainBytes));
                Console.WriteLine("加密后的数组:{0}", FormatBytes(eBytes));
                Console.WriteLine("解密后的数组:{0}", FormatBytes(dBytes));
                Console.WriteLine("解密的明文:{0}", Encoding.UTF8.GetString(dBytes));
            }
static string FormatBytes(byte[] bytes,byte countInLine = 10)
        {
            StringBuilder sb = new StringBuilder();
            int i = 0;
            foreach (byte b in bytes)
            {
                if (i++ % countInLine == 0)
                    sb.Append(\n);
                sb.Append(String.Format("{0:X2}  ", b));
            }
            sb.Append(\b);

            return sb.ToString();
        }
bubuko.com,布布扣

C# AES,AesManaged使用学习,布布扣,bubuko.com

C# AES,AesManaged使用学习

标签:style   blog   http   color   使用   os   io   for   

原文地址:http://www.cnblogs.com/bushuosx/p/3905616.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!