C#中使用DES加密解密

 

     DES算法为密码体制中的对称密码体制,又被称为美国数据加密标准,是1972年美国IBM公司研制的对称密码体制加密算法。 明文按64位进行分组,密钥长64位,密钥事实上是56位参与DES运算(第8、16、24、32、40、48、56、64位是校验位, 使得每个密钥都有奇数个1)分组后的明文组和56位的密钥按位替代或交换的方法形成密文组的加密方法。

    其入口参数有三个:key、data、mode。key为加密解密使用的密钥,data为加密解密的数据,mode为其工作模式。当模式为加密模式时,明文按照64位进行分组,形成明文组,key用于对数据加密,当模式为解密模式时,key用于对数据解密。实际运用中,密钥只用到了64位中的56位,这样才具有高的安全性。

     des标准现在已经被aes取代,主要使用md5加密

  • "DES":   数据加密算法(Data Encryption Algorithm,DEA)是一种对称加密算法,很可能是使用最广泛的密钥系统,特别是在保护金融数据的安全中,最初开发的DEA是嵌入硬件中的。通常,自动取款机(Automated Teller Machine,ATM)都使用DEA。它出自IBM的研究工作,IBM也曾对它拥有几年的专利权,但是在1983年已到期后,处于公有范围中,允许在特定条件下可以免除专利使用费而使用。1977年被美国政府正式采纳。

  • "AES":   高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。经过五年的甄选流程,高级加密标准由美国国家标准与技术研究院(NIST)于2001年11月26日发布于FIPS PUB 197,并在2002年5月26日成为有效的标准。2006年,高级加密标准已然成为对称密钥加密中最流行的算法之一。

     

优点:“DES”:运算速度快,资源消耗较少;“AES”:运算速度快,安全性高,资源消耗少

缺点:“DES”:安全性低


DES,全称Data Encryption Standard,是一种对称加密算法。由于其安全性比较高(有限时间内,没有一种加密方法可以说是100%安全),很可能是最广泛的密钥系统(我们公司也在用,估计你们也有在用....),唯一一种方法可以破解该算法,那就是穷举法。

扫描二维码关注公众号,回复: 1372551 查看本文章

  加密和解密本身是一门很复杂的学科,本文浅操,我就不去探究起加密的过程和原理。如果要深究的话,肯定是要花写精力的,写这篇文章只有两个方法,一个是加密,一个是解密的。比较简洁,送给小白。引用的命名空间是using System.Security.Cryptography,用到了一下类

DESCryptoServiceProvider:定义访问数据加密标准,算法的加密服务提供程序 (CSP) 版本的包装对象

MemoryStream:内存流

CryptoStream:加密数据流的转换


des加密解密的过程主要有四个参数参与其中:明文、密钥、向量、加密结果。他们之间的关系很好理解,加密过程是这样的,加密结果=明文+密钥+向量,反之也是一样的。值得注意的是密钥和向量字符串长度必须为8.

C# des加密解密

C#DES加密方法:

[csharp]  view plain  copy
  1. /// <summary>  
  2. /// C# DES解密方法  
  3. /// </summary>  
  4. /// <param name="encryptedValue">待解密的字符串</param>  
  5. /// <param name="key">密钥</param>  
  6. /// <param name="iv">向量</param>  
  7. /// <returns>解密后的字符串</returns>  
  8. public static string DESDecrypt(string encryptedValue, string key, string iv)  
  9. {  
  10.     using (DESCryptoServiceProvider sa =  
  11.         new DESCryptoServiceProvider  
  12.         { Key = Encoding.UTF8.GetBytes(key), IV = Encoding.UTF8.GetBytes(iv) })  
  13.     {  
  14.         using (ICryptoTransform ct = sa.CreateDecryptor())  
  15.         {  
  16.             byte[] byt = Convert.FromBase64String(encryptedValue);  
  17.   
  18.             using (var ms = new MemoryStream())  
  19.             {  
  20.                 using (var cs = new CryptoStream(ms, ct, CryptoStreamMode.Write))  
  21.                 {  
  22.                     cs.Write(byt, 0, byt.Length);  
  23.                     cs.FlushFinalBlock();  
  24.                 }  
  25.                 return Encoding.UTF8.GetString(ms.ToArray());  
  26.             }  
  27.         }  
  28.     }  
  29. }  

C#DES解密方法:

[csharp]  view plain  copy
  1. /// <summary>  
  2. /// C# DES加密方法  
  3. /// </summary>  
  4. /// <param name="encryptedValue">要加密的字符串</param>  
  5. /// <param name="key">密钥</param>  
  6. /// <param name="iv">向量</param>  
  7. /// <returns>加密后的字符串</returns>  
  8. public static string DESEncrypt( string originalValue, string key, string iv)  
  9. {  
  10.     using (DESCryptoServiceProvider sa  
  11.         = new DESCryptoServiceProvider { Key = Encoding.UTF8.GetBytes(key), IV =Encoding.UTF8.GetBytes(iv)})  
  12.     {  
  13.         using (ICryptoTransform ct = sa.CreateEncryptor())  
  14.         {  
  15.             byte[] by = Encoding.UTF8.GetBytes(originalValue);  
  16.             using (var ms = new MemoryStream())  
  17.             {  
  18.                 using (var cs = new CryptoStream(ms, ct,  
  19.                                                  CryptoStreamMode.Write))  
  20.                 {  
  21.                     cs.Write(by, 0, by.Length);  
  22.                     cs.FlushFinalBlock();  
  23.                 }  
  24.                 return Convert.ToBase64String(ms.ToArray());  
  25.             }  
  26.         }  
  27.     }  
  28. }  

猜你喜欢

转载自blog.csdn.net/weixin_38353287/article/details/80423144
今日推荐