标签:加密 19 RijndaelManaged return result str new byte
public string Encrypt(string str) { string result = null; if (str == null) { return result; } try { byte[] array0 = Encoding.ASCII.GetBytes(str); MemoryStream stream = new MemoryStream(array0); RijndaelManaged rijndaelManaged = new RijndaelManaged(); byte[] key = new byte[32] { 5, 1, 3, 28, 27, 3, 2, 16, 12, 19, 39, 200, 10, 18, 181, 79, 103, 61, 145, 215, 125, 212, 131, 241, 229, 254, 250, 205, 11, 29, 83, 125 }; byte[] vi = new byte[16] { 204, 19, 18, 10, 147, 108, 20, 177, 26, 171, 19, 143, 38, 112, 19, 12 }; ICryptoTransform transform = rijndaelManaged.CreateEncryptor(key, vi); CryptoStream cryptoStream = new CryptoStream(stream, transform, CryptoStreamMode.Write); result = cryptoStream.ToString(); cryptoStream.FlushFinalBlock(); return result; } catch { return null; } } public string Decode(string str) { string result = null; if (str == null) { return result; } try { byte[] array0 = Encoding.ASCII.GetBytes(str); MemoryStream stream = new MemoryStream(array0); RijndaelManaged rijndaelManaged = new RijndaelManaged(); byte[] key = new byte[32] { 5, 1, 3, 28, 27, 3, 2, 16, 12, 19, 39, 200, 10, 18, 181, 79, 103, 61, 145, 215, 125, 212, 131, 241, 229, 254, 250, 205, 11, 29, 83, 125 }; byte[] vi = new byte[16] { 204, 19, 18, 10, 147, 108, 20, 177, 26, 171, 19, 143, 38, 112, 19, 12 }; ICryptoTransform transform = rijndaelManaged.CreateEncryptor(key, vi); CryptoStream inStream = new CryptoStream(stream, transform, CryptoStreamMode.Read); return inStream.ToString(); } catch { return null; } }
1.代码中key和vi分别对应加密器对象Key和初始化向量 (IV)
2.Key和VI只有完全匹配得上加密数据才可以被解密
标签:加密,19,RijndaelManaged,return,result,str,new,byte 来源: https://www.cnblogs.com/Khan-Sadas/p/11058233.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。