2009-04-15 71 views
2

采取以下代码:DES加密在C#

DESCryptoServiceProvider des = new DESCryptoServiceProvider(); 
des.Key = new byte[] { 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08}; 
ICryptoTransform encryptor = des.CreateEncryptor(); 
// encrypt 
byte[] x = UTF8Encoding.UTF8.GetBytes("thisIsATEST"); 
byte[] enc = encryptor.TransformFinalBlock(x, 0, x.Length); 
string savedValue = Convert.ToBase64String(enc); 



DESCryptoServiceProvider des1 = new DESCryptoServiceProvider(); 
des1.Key = new byte[] { 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08}; 
ICryptoTransform decryptor = des1.CreateDecryptor(); 
byte[] y = Convert.FromBase64String(savedValue); 
// decrypt 
byte[] originalAgain = decryptor.TransformFinalBlock(y, 0, y.Length); 
System.Text.ASCIIEncoding e = new System.Text.ASCIIEncoding(); 
string str = e.GetString(originalAgain); 

现在这不起作用解密但是如果des1.CreateDecryptor();更改为des.CreateDecryptor();它工作正常,我不确定为什么如果我使用完全相同的密钥。

它没有引发异常,它只是不正确地转换字符串。

回答

4

除非你使用类似ECB模式的东西,否则解密器需要加密器使用的初始化向量。

3

这是因为你没有设置初始化矢量(IV),DESCryptoServiceProvider会自动为你生成一个,因为你有两个不同的实例,它们将会不同。