gpt4 book ai didi

python - 使用 3DES 和 CBC 破坏我的加密数据的前 8 个字节

转载 作者:太空狗 更新时间:2023-10-30 01:09:07 25 4
gpt4 key购买 nike

我在应用程序中使用 PyCrypto 来加密数据,但出于某种原因,无论我做什么,前 8 个字节(对应于第一个 block )都会损坏。

>>> from Crypto.Cipher import DES3
>>> from Crypto import Random
>>> iv = Random.new().read(DES3.block_size)
>>> key = Random.new().read(DES3.key_size[-1])
>>> des3 = DES3.new(key, DES3.MODE_CBC, iv)
>>> des3.decrypt(des3.encrypt('12345678abcdefgh12345678'))
't\x1b\x0f\xcbD\x15M\xababcdefgh12345678'

我读到这表明 IV 已损坏,但这些消息来源还表示,使用 CBC 以外的模式会导致整个消息损坏。事实并非如此:

>>> des3 = DES3.new(key, DES3.MODE_CFB, iv)
>>> des3.decrypt(des3.encrypt('12345678abcdefgh12345678'))
'\xe1\x85\xae,\xf1m\x83\x9cabcdefgh12345678'

我也可以排除密码的原因:

>>> from Crypto.Cipher import AES
>>> from Crypto import Random
>>> iv = Random.new().read(AES.block_size)
>>> key = Random.new().read(AES.key_size[-1])
>>> aes = AES.new(key, AES.MODE_CBC, iv)
>>> aes.decrypt(aes.encrypt('12345678abcdefgh12345678abcdefgh'))
'\xa7l\x00]\x1cW\xec\xd0\x04\x06\xba&\x1663\xd712345678abcdefgh'

请注意,在此示例中,前 16 个字节已损坏,这对应于 AES 的 block 大小。

最佳答案

您必须在解密前重置 IV 向量。试试这个代码:

>>> from Crypto.Cipher import DES3
>>> from Crypto import Random
>>> iv = Random.new().read(DES3.block_size)
>>> key = Random.new().read(DES3.key_size[-1])
>>> des3enc = DES3.new(key, DES3.MODE_CBC, iv)
>>> des3dec = DES3.new(key, DES3.MODE_CBC, iv)
>>> des3dec.decrypt(des3enc.encrypt('12345678abcdefgh12345678'))

IV 向量在加密/解密每个 block 后都会发生变化。您使用 DES3 类的相同实例来加密和解密消息,因此您的解密 IV 不正确。

希望上面的代码有效——我没有测试它。

关于 CBC 模式的更多信息:http://en.wikipedia.org/wiki/Block_cipher_mode_of_operation

关于python - 使用 3DES 和 CBC 破坏我的加密数据的前 8 个字节,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16349441/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com