采取以下代码:
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(); 它工作正常我不确定为什么如果我使用完全相同的密钥。
它没有抛出异常,只是没有正确转换字符串。
答案 0 :(得分:5)
除非您使用类似ECB模式的东西,否则解密器需要加密器使用的初始化向量。
答案 1 :(得分:4)
这是因为您没有设置初始化向量(IV),DESCryptoServiceProvider会自动为您生成一个,并且因为您有2个单独的实例,它们将会有所不同。