3

我是加密/解密的新手。我正在尝试解密一个加密的输入字符串,输出为 44 个字符。

这是我到目前为止所拥有的,但是当它尝试执行“TransformFinalBlock”函数时,我不断收到“错误数据”。

public static String Decrypt(String input)
    {
        try{
            byte[] inputArray = Convert.FromBase64String(input);
            TripleDESCryptoServiceProvider tripleDES = new TripleDESCryptoServiceProvider();
            tripleDES.KeySize = 128;
            tripleDES.Key = UTF8Encoding.UTF8.GetBytes("0123456789ABCDEF");
            tripleDES.IV = UTF8Encoding.UTF8.GetBytes("ABCDEFGH");
            tripleDES.Mode = CipherMode.ECB;
            tripleDES.Padding = PaddingMode.PKCS7;
            ICryptoTransform transform = tripleDES.CreateDecryptor();
            byte[] resultArray = transform.TransformFinalBlock(inputArray, 0, inputArray.Length);
            tripleDES.Clear();

            return UTF8Encoding.UTF8.GetString(resultArray);
        }
        catch(Exception except){
            Debug.WriteLine(except + "\n\n" + except.StackTrace);
            return null;
        }
    }
4

2 回答 2

5

如果您使用 IV,那么您应该使用CipherMode.CBC. 欧洲央行不使用任何 IV。

此外,您的数据根本没有填充,它正好包含 32 个字节。要测试解密,通常先尝试不进行填充。这样,您可以通过查看生成的明文来确定使用了哪个填充。

普通数据太老土了,无法在这里打印,所以我不会。

于 2012-05-17T00:40:07.157 回答
3

我有一个非常相似的问题,我通过将PaddingMode更改为None来修复它

我的CipherModeECB(电子密码本)。

于 2015-07-29T20:35:13.713 回答