C# - AES加密+解密
2013-02-20 17:47
246 查看
/// 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; }
相关文章推荐
- C#实现DES加密解密,AES加密解密
- Java aes加密C#解密的取巧方法
- AES 256 加密和解密 for C#
- C#实现对AES加密和解密的方法
- AES加密解密通用版Object-C / C# / JAVA
- C#之AES256位加密解密
- C#实现AES加密和解密函数
- C#中使用DES和AES加密解密
- C# 跨平台于Java的AES加密解密
- C#使用DES和AES实现加密解密功能示例
- AES加密,解密 C# .net 解密支持大文件
- C#实现256位AES加密和解密
- [转]C# 使用 256 位 AES 加密和解密文件
- AES Java加密 C#解密 (128-ECB加密模式)
- .Net(c#)加密解密之Aes和Des
- c#和js互通的AES加密解密
- javascript AES加密 C#AES解密实现
- C#实现AES加密解密
- C# AES加密解密
- Aes使用Java加密C#解密