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

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

报告相同问题?

悬赏问题

  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码