1

我有下一个代码:

FileStream fs = new FileStream("test.crp",FileMode.Create);
Aes aes = Aes.Create();
FileStream fsKeys = new FileStream("keys.key",FileMode.Open);
fsKeys.Read(aes.IV,0,16);
fsKeys.Read(aes.Key,0,32);
fsKeys.Close();

问题是:在从文件读取操作期间,aes.IV 和 aes.Key 没有改变。

而且我只能使用赋值运算符为它们分配一个新值:

 byte [] iv = new byte[16];
 byte [] key = new byte[32];
 aes.IV = iv;
 aes.Key = key;

这是正确的行为吗?如果是这样,那么当我使用 fs.Read 时,我应该读取哪个内存块?

4

1 回答 1

1

那是因为Aes.IV并且Aes.Key正在返回其成员变量的“克隆”字节数组。

通过fsKeys.Read(aes.IV,0,16);,您正在修改克隆的 IV 数组,而不是后面的成员变量aes.IV

您可以在此处查看源代码: https ://referencesource.microsoft.com/#mscorlib/system/security/cryptography/symmetricalgorithm.cs,97c6f2476150a40d

于 2017-11-14T05:30:18.727 回答