您身边的软件定制专家--9年开发经验为您护航

18678812288
0531-88887250

C# 实现3Des加密 解密

文章作者:济南软件开发 时间:2016年12月20日

3Des对每个数据块进行了三次的DES加密算法,是DES的一个更安全的变形。比起最初的DES,3DES更为安全。

 

都是感觉一目了然的摘过来。

 

下面是加密解密的源码。ECB模式的。

 

 1 public class _3DESEncrypt

 2     {

 3 

 4         public static string Encrypt3DES(string a_strString, string a_strKey)

 5         {

 6             TripleDESCryptoServiceProvider DES = new TripleDESCryptoServiceProvider();

 7             DES.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(a_strKey, "md5").Substring(0, 24));

 8             DES.Mode = CipherMode.ECB;

 9             ICryptoTransform DESEncrypt = DES.CreateEncryptor();

10             byte[] Buffer = ASCIIEncoding.ASCII.GetBytes(a_strString);

11             return Convert.ToBase64String(DESEncrypt.TransformFinalBlock(Buffer, 0, Buffer.Length));

12         }

13 

14         public static string Decrypt3DES(string a_strString, string a_strKey)

15         {

16             TripleDESCryptoServiceProvider DES = new TripleDESCryptoServiceProvider();

17             DES.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(a_strKey, "md5").Substring(0, 24));

18             DES.Mode = CipherMode.ECB;

19             DES.Padding = System.Security.Cryptography.PaddingMode.PKCS7;

20             ICryptoTransform DESDecrypt = DES.CreateDecryptor();

21             string result = "";

22             try

23             {

24                 byte[] Buffer = Convert.FromBase64String(a_strString);

25 

26                 result = ASCIIEncoding.ASCII.GetString(DESDecrypt.TransformFinalBlock(Buffer, 0, Buffer.Length));

27 

28                 //MemoryStream msDecrypt = new MemoryStream(Buffer);

29                 //CryptoStream csDecrypt = new CryptoStream(msDecrypt,

30                 //       DES.CreateDecryptor(DES.Key, DES.IV),

31                 //       CryptoStreamMode.Read);

32 

33                 //// Create buffer to hold the decrypted data.

34                 //byte[] fromEncrypt = new byte[Buffer.Length];

35 

36                 //// Read the decrypted data out of the crypto stream

37                 //// and place it into the temporary buffer.

38                 //csDecrypt.Read(fromEncrypt, 0, fromEncrypt.Length);

39                 //result = System.Text.Encoding.Default.GetString(fromEncrypt);

40             }

41             catch (Exception e)

42             {

43             }

44             return result;

45 

46         }

47     }

 

里面加解密都是在DES的基础上实现、区别在于3Des的Key值是24位、DES而是8位。


想要了解更多详情欢迎来电咨询18678812288
登陆网址:www.jnydkj.cn。
联系人:王经理。