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
  • 相关阅读:
    JVM学习五:JVM之类加载器之编译常量和主动使用
    JVM学习一:JVM之类加载器概况
    JVM学习三:JVM之类加载器之连接分析
    JVM学习二:JVM之类加载器之加载分析
    JVM学习四:JVM之类加载器之初始化分析
    高斯滤波详解 附python和matlab高斯滤波代码
    图像最大池化
    图像平均池化 pytorch库中的平均池化
    图像色彩量化处理
    图像RGB到HSV色彩空间转换及其逆变换
  • 原文地址:https://www.cnblogs.com/bushuosx/p/3905616.html
Copyright © 2011-2022 走看看