zhang_jiafeng 2016-03-28 02:52 采纳率: 25%
浏览 6368

C#AES加密时,怎么产生密钥和密钥向量?

各位大神好,最近在做一个一个项目,牵扯到加密,网上搜到了加密算法,但是不知道AES的机密密钥和密钥向量怎么产生?烦请各位为小弟指点一下~

  • 写回答

1条回答

  • lx624909677 2016-03-28 06:15
    关注
     /// AES加密
            /// </summary>
            /// <param name="inputdata">输入的数据</param>
            /// <param name="iv">向量128位</param>
            /// <param name="strKey">加密密钥</param>
            /// <returns></returns>
            public static byte[] AESEncrypt(byte[] inputdata, byte[] iv, string strKey)
            {
                //分组加密算法   
                SymmetricAlgorithm des = Rijndael.Create();
                byte[] inputByteArray = inputdata;//得到需要加密的字节数组       
                //设置密钥及密钥向量
                des.Key = Encoding.UTF8.GetBytes(strKey.Substring(0, 32));
                des.IV = iv;
                using (MemoryStream ms = new MemoryStream())
                {
                    using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
                    {
                        cs.Write(inputByteArray, 0, inputByteArray.Length);
                        cs.FlushFinalBlock();
                        byte[] cipherBytes = ms.ToArray();//得到加密后的字节数组   
                        cs.Close();
                        ms.Close();                   
                        return cipherBytes;
                    }
                }
            }
    
    
            /// <summary>
            /// AES解密
            /// </summary>
            /// <param name="inputdata">输入的数据</param>
            /// <param name="iv">向量128</param>
            /// <param name="strKey">key</param>
            /// <returns></returns>
            public static byte[] AESDecrypt(byte[] inputdata, byte[] iv, string strKey)
            {
                SymmetricAlgorithm des = Rijndael.Create();
                des.Key = Encoding.UTF8.GetBytes(strKey.Substring(0, 32));
                des.IV = iv;
                byte[] decryptBytes = new byte[inputdata.Length];
                using (MemoryStream ms = new MemoryStream(inputdata))
                {
                    using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Read))
                    {
                        cs.Read(decryptBytes, 0, decryptBytes.Length);
                        cs.Close();
                        ms.Close();
                    }
                }
                return decryptBytes;
            }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥65 汇编语言除法溢出问题