我有以下代码:
var symmetricKey = Rijndael.Create().CreateEncryptor(key, iv);
key和iv的长度相同,它们是长度为32的字节数组。 在运行时,此代码段失败,表示不支持长度。 我也试过16。也不起作用。
我使用这个错了吗?什么给了?
答案 0 :(得分:1)
如果将IV设置为16字节,匹配Rijndael的默认块大小,它应该可以正常工作。
(或者更改BlockSize
本身以与IV的大小兼容。)
答案 1 :(得分: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);
}
}
}