不一致解密時,我創建了一個類用於加密和使用AES解密。.NET AES/Rijndael算法 - 重用解密
public class AesEncryptionProvider {
#region Fields
// Encryption key
private static readonly byte[] s_key = new byte[32] {
// Omitted...
};
// Initialization vector
private static readonly byte[] s_iv = new byte[16] {
// Omitted...
};
private AesCryptoServiceProvider m_provider;
private ICryptoTransform m_encryptor;
private ICryptoTransform m_decryptor;
#endregion
#region Constructors
private AesEncryptionProvider() {
m_provider = new AesCryptoServiceProvider();
m_encryptor = m_provider.CreateEncryptor(s_key, s_iv);
m_decryptor = m_provider.CreateDecryptor(s_key, s_iv);
}
static AesEncryptionProvider() {
Instance = new AesEncryptionProvider();
}
#endregion
#region Properties
public static AesEncryptionProvider Instance { get; private set; }
#endregion
#region Methods
public string Encrypt (string value) {
if (string.IsNullOrEmpty(value)) {
throw new ArgumentException("Value required.");
}
return Convert.ToBase64String(
Transform(
Encoding.UTF8.GetBytes(value),
m_encryptor));
}
public string Decrypt (string value) {
if (string.IsNullOrEmpty(value)) {
throw new ArgumentException("Value required.");
}
return Encoding.UTF8.GetString(
Transform(
Convert.FromBase64String(value),
m_decryptor));
}
#endregion
#region Private methods
private byte[] Transform (byte[] input, ICryptoTransform transform) {
byte[] output;
using (MemoryStream memory = new MemoryStream()) {
using (CryptoStream crypto = new CryptoStream(
memory,
transform,
CryptoStreamMode.Write
)) {
crypto.Write(input, 0, input.Length);
crypto.FlushFinalBlock();
output = memory.ToArray();
}
}
return output;
}
#endregion
}
正如你可以看到,在這兩種情況下,我通過CryptoStream
寫爲MemoryStream
。如果我在Decrypt
的每個調用中都通過m_provider.CreateDecyptor(s_key, s_iv)
創建一個新的解密器,它就可以工作。
出了什麼錯在這裏?爲什麼解密者表現得好像忘記了IV?有沒有什麼呼籲StreamReader.ReadToEnd()
這樣做有助於m_decryptor
正常工作?
我想避免我在這裏列出的兩種「工作」方法中的任何一種,因爲這兩種方法都會對性能造成影響,這是一條非常關鍵的途徑。提前致謝。
請發佈**加密和解密的**實際**代碼。這種做法聽起來不像是有問題的。 – 2010-07-29 21:32:02
更新完整的課程。 – iamtyler 2010-07-29 21:53:34