0

我有以下代码:

var symmetricKey = Rijndael.Create().CreateEncryptor(key, iv);

key 和 iv 的长度相同,它们是长度为 32 的字节数组。在运行时,此代码段失败,表示不支持该长度。我也试过 16. 也不起作用。

我用错了吗?是什么赋予了?

4

2 回答 2

1

如果将 IV 设置为 16 字节,它应该可以正常工作,匹配 Rijndael 的默认块大小。

(要么改变它BlockSize本身,要么改变它以与你的 IV 的大小兼容。)

于 2011-07-22T09:26:53.127 回答
0

此代码应作为示例工作:

        byte[] key = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 };
        byte[] iv = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 };

        byte[] data = { 1, 2, 3, 4, 5 };   

        using (var symmetrickey = Rijndael.Create().CreateEncryptor(key, iv))
        {
            using (Stream f = File.Create("anencryptedfile.bin"))
            {
                using (Stream c = new CryptoStream(f, symmetrickey, CryptoStreamMode.Write))
                {
                    c.Write(data, 0, data.Length);
                }
            }
        }
于 2011-07-22T09:30:31.863 回答