是否需要初始化向量才能解密我的数据?

发布于 2024-12-08 15:45:49 字数 111 浏览 3 评论 0原文

我正在使用 RijndaelManaged 来加密和解密数据。我很可能误解了初始化向量的意义,但我发现如果我在解密数据时将其设置为不同的值,则除前 16 个字符外的所有字符仍然可以正确解密。这是预期的行为吗?

I'm using RijndaelManaged to encrypt and decrypt data. I may well have misunderstood the point of an initialization vector, but I am finding that if I set it to a different value when decrypting my data, all but the first 16 characters are still decrypted correctly. Is that expected behaviour?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

牵你的手,一向走下去 2024-12-15 15:45:49

是的。在 CBC 模式中,每个密文块用作下一个密文块的 IV。使用错误的 IV 会弄乱第一个 16 字节块,但后续块将不受影响。这可能是一个有用的属性,因为它允许在错误块后进行错误恢复,这在某些情况下可能很重要。它还说明了为什么实际上没有必要对 IV 保密(与密钥不同!)。

Yes. In CBC mode each cyphertext block is used as the IV for the next cyphertext block. Using a faulty IV will mess up the first 16 byte block, but subsequent blocks will be unaffected. This can be a useful property as it allows error recovery after a faulty block, which can be important in some situations. It also illustrates why it is not really necessary to keep the IV secret (unlike the key!).

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文