zoukankan      html  css  js  c++  java
  • C# AES,AesManaged使用学习

    加密

    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('
    ');
                    sb.Append(String.Format("{0:X2}  ", b));
                }
                sb.Append('');
    
                return sb.ToString();
            }
    aesmanaged
  • 相关阅读:
    HTML转换成word文档
    泛型的导入导出的公用方法
    封装的分页jq
    用泛型做的分页类
    EntityFramework小知识
    泛型连接数据库
    在博客园看的一些小技巧
    渗透之路基础 -- SQL注入
    第一篇博客就这么开始了?!稍微介绍一下。
    正则基础用法
  • 原文地址:https://www.cnblogs.com/bushuosx/p/3905616.html
Copyright © 2011-2022 走看看