AES解密在中文语言环境中失败,且字符错误无效

时间:2015-07-27 09:28:18

标签: c# encryption character-encoding aes

我有以下代码:

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来解决这个问题。我试了但是出现了同样的错误。

1 个答案:

答案 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

再次感谢!