C#中DES加密解密

加密和解密是一门高深和复杂的学科。在程序中有时需要用一些简单的加密和解密,以保证一些关键字符串、值等地安全性。这里就要用到DES加密解密。当然我们不用深究这些加密的原理了,因为如果深究的话估计都得转行研究数学。DES加密解密C#中需要用到这几个类,DESCryptoServiceProvider,CryptoStream。

看下面的两组加密解密代码。

1、

       (1)、对字符串进行DES加密

[csharp]  view plain copy print ?
  1.         public static string Encrypt(string sourceString, string key, string iv)  
  2.         {  
  3.             try  
  4.             {  
  5.                 byte[] btKey = Encoding.UTF8.GetBytes(key);  
  6.   
  7.                 byte[] btIV = Encoding.UTF8.GetBytes(iv);  
  8.   
  9.                 DESCryptoServiceProvider des = new DESCryptoServiceProvider();  
  10.   
  11.                 using (MemoryStream ms = new MemoryStream())  
  12.                 {  
  13.                     byte[] inData = Encoding.UTF8.GetBytes(sourceString);  
  14.                     try  
  15.                     {  
  16.                         using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(btKey, btIV), CryptoStreamMode.Write))  
  17.                         {  
  18.                             cs.Write(inData, 0, inData.Length);  
  19.   
  20.                             cs.FlushFinalBlock();  
  21.                         }  
  22.   
  23.                         return Convert.ToBase64String(ms.ToArray());  
  24.                     }  
  25.                     catch  
  26.                     {  
  27.                         return sourceString;  
  28.                     }  
  29.                 }  
  30.             }  
  31.             catch { }  
  32.   
  33.             return "DES加密出错";  
  34.         }  
  35. 调用:  
  36.             string recordString = Encrypt("金胖子死了""20111219""12345678");  
  37. 结果:recordString= "xQ969nexy964SXhkTuekUQ=="  

(2)、 对DES加密后的字符串进行解密

[csharp]  view plain copy print ?
  1.         public static string Decrypt(string encryptedString, string key, string iv)  
  2.         {  
  3.             byte[] btKey = Encoding.UTF8.GetBytes(key);  
  4.   
  5.             byte[] btIV = Encoding.UTF8.GetBytes(iv);  
  6.   
  7.             DESCryptoServiceProvider des = new DESCryptoServiceProvider();  
  8.   
  9.             using (MemoryStream ms = new MemoryStream())  
  10.             {  
  11.                 byte[] inData = Convert.FromBase64String(encryptedString);  
  12.                 try  
  13.                 {  
  14.                     using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(btKey, btIV), CryptoStreamMode.Write))  
  15.                     {  
  16.                         cs.Write(inData, 0, inData.Length);  
  17.   
  18.                         cs.FlushFinalBlock();  
  19.                     }  
  20.   
  21.                     return Encoding.UTF8.GetString(ms.ToArray());  
  22.                 }  
  23.                 catch  
  24.                 {  
  25.                     return encryptedString;  
  26.                 }  
  27.             }  
  28.         }  
  29. 调用:string recordString = DESOperation.Decrypt("xQ969nexy964SXhkTuekUQ==""20111219""12345678");  
  30. 结果:recordString = “金胖子死了”;  

2、

  (1)、加密字符串

[csharp]  view plain copy print ?
  1.         public static string EncryptString(string sInputString, string sKey, string sIV)  
  2.         {  
  3.             try  
  4.             {  
  5.                 byte[] data = Encoding.UTF8.GetBytes(sInputString);  
  6.   
  7.                 DESCryptoServiceProvider DES = new DESCryptoServiceProvider();  
  8.   
  9.                 DES.Key = ASCIIEncoding.ASCII.GetBytes(sKey);  
  10.   
  11.                 DES.IV = ASCIIEncoding.ASCII.GetBytes(sIV);  
  12.   
  13.                 ICryptoTransform desencrypt = DES.CreateEncryptor();  
  14.   
  15.                 byte[] result = desencrypt.TransformFinalBlock(data, 0, data.Length);  
  16.   
  17.                 return BitConverter.ToString(result);  
  18.             }  
  19.             catch { }  
  20.   
  21.             return "转换出错!";  
  22.         }  
  23. 调用:string recordString = DESOperation.EncryptString("金胖子死了""20111219""12345678");  
  24. 结果:recordString = "C5-0F-7A-F6-77-B1-CB-DE-B8-49-78-64-4E-E7-A4-51";  

(2)、解密字符串

[csharp]  view plain copy print ?
  1.         public static string DecryptString(string sInputString, string sKey, string sIV)  
  2.         {  
  3.             try  
  4.             {  
  5.                 string[] sInput = sInputString.Split("-".ToCharArray());  
  6.   
  7.                 byte[] data = new byte[sInput.Length];  
  8.   
  9.                 for (int i = 0; i < sInput.Length; i++)  
  10.                 {  
  11.                     data[i] = byte.Parse(sInput[i], NumberStyles.HexNumber);  
  12.                 }  
  13.   
  14.                 DESCryptoServiceProvider DES = new DESCryptoServiceProvider();  
  15.   
  16.                 DES.Key = ASCIIEncoding.ASCII.GetBytes(sKey);  
  17.   
  18.                 DES.IV = ASCIIEncoding.ASCII.GetBytes(sIV);  
  19.   
  20.                 ICryptoTransform desencrypt = DES.CreateDecryptor();  
  21.   
  22.                 byte[] result = desencrypt.TransformFinalBlock(data, 0, data.Length);  
  23.   
  24.                 return Encoding.UTF8.GetString(result);  
  25.             }  
  26.             catch { }  
  27.   
  28.             return "解密出错!";  
  29.         }  
  30. 调用:string recordString = DESOperation.DecryptString("C5-0F-7A-F6-77-B1-CB-DE-B8-49-78-64-4E-E7-A4-51""20111219""12345678");  
  31. 结果:recordString =” 金胖子死了”;  

注意:密钥和向量必须为8位,否则加密解密都不成功。



D.E.S 是分块加密的,将明文分割成 64 BITS 的块, 然后他们一个个接起来 。他使用56位密钥对64位的数据块进行加密,并对64bits的数据块进行16轮编码。和每轮编码时,一个48bits的“每轮”密钥值由56bits的完整密钥得出来。DES用软件进行解码需要用非常长时间,而用硬件解码速度非常快,1977年,人们估计要耗资两千万美元才能建成一个专门计算机用于DES的解密,而且需要12个小时的破解才能得到结果。所以,当时DES被认为是一种十分强壮的加密方法。但今天, 只需 二十万美圆就能制造一台破译DES的特别的计算机,所以目前 DES 对需求“强壮”加密的场合已不再适用了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值