我有以下代码:
private static string AesDecrypt(string text, string key)
{
var encoding = Encoding.Default;
var aes = new RijndaelManaged
{
KeySize = 256,
BlockSize = 256,
Padding = PaddingMode.Zeros,
Mode = CipherMode.CBC,
Key = encoding.GetBytes(key)
};
text = encoding.GetString(Convert.FromBase64String(text));
var iv = text;
iv = iv.Substring(iv.IndexOf("-[--IV-[-", StringComparison.Ordinal) + 9);
text = text.Replace("-[--IV-[-" + iv, "");
text = Convert.ToBase64String(encoding.GetBytes(text));
aes.IV = encoding.GetBytes(iv);
using (var aesDecrypt = aes.CreateDecryptor(aes.Key, aes.IV))
{
var buffer = Convert.FromBase64String(text);
var result = encoding.GetString(aesDecrypt.TransformFinalBlock(buffer, 0, buffer.Length));
result = result.Substring(0, result.IndexOf(Convert.ToChar(0)));
return result;
}
}
private static string AesEncrypt(string text, string key)
{
var encoding = Encoding.Default;
var aes = new RijndaelManaged
{
KeySize = 256,
BlockSize = 256,
Padding = PaddingMode.Zeros,
Mode = CipherMode.CBC,
Key = (encoding.GetBytes(key))
};
aes.GenerateIV();
var iv = ("-[--IV-[-" + encoding.GetString(aes.IV));
using (var aesEncrypt = aes.CreateEncryptor(aes.Key, aes.IV))
{
var buffer = encoding.GetBytes(text);
return Convert.ToBase64String(encoding.GetBytes(encoding.GetString(aesEncrypt.TransformFinalBlock(buffer, 0, buffer.Length)) + iv));
}
}
通过具有英语(美国)语言环境的系统访问它时,它可以正常工作。但是,一旦我在具有中文语言环境的系统中尝试它,它会引发以下错误:
指定的初始化向量(IV)与块大小不匹配 这个算法。
或
Base-64字符串中的字符无效。
有些消息来源说我应该使用Encoding.UTF8或Encoding.Unicode来解决这个问题。我试了但是出现了同样的错误。
答案 0 :(得分:0)
它似乎更像是一个字符串解码问题而不是像Rawling这样的加密问题。谢谢你指出这一点。
无论如何,我没有使用Encoding.Default,Encoding.UTF或Encoding.Unicode,而是尝试使用基于美国的编码(OEM美国)来解决我的问题:
Encoding.GetEncoding(437);
https://msdn.microsoft.com/en-us/library/system.text.encoding(v=vs.110).aspx
再次感谢!