0

这简直让我发疯。

这就是发生的事情:

在 python 外壳内部:

>>> from Crypto.Cipher import ARC4
>>> a = ARC4.new('0123456789123456')
>>> b = ARC4.new('0123456789123456')
>>> de = b.decrypt
>>> en = a.encrypt
>>> en('abcd')
'\x18\x07\x8a\xdc'
>>> en('abcd')
'\x89>\xa0T'
>>> en('abcd')
'y\xe1-\xfe'
>>> en('abcd')
'\xc7\xf6\x19\xfc'
>>> 

我用相同的密钥加密abcd了 4 次。并且所有四次我都得到了不同的加密字符串。

当我做了以下事情时(也许我会在解密上述所有不同的加密消息时得到相同的解密消息)。

>>> al  = []
>>> for i in range(10):
    al.append(en('abcd'))


>>> al
['\x81\x05h\x06', '\x11;\x88\xc7', '\xb6\xb9g\x10', '\x1e$\x8c\xca', '\xbdh\xc2\xf0', 'ruiO', '7\xec\x7f\xdf', '\x08\xf3\x90\x8a', '\x1c\x95\xf3(', '\xbd@-\x11']

>>> gl = []
>>> for i in range(10):
    gl.append(de(al[i]))


>>> gl
['\xc8\x0f6\xb7', '\x18y`A', 'tm\x12\t', '\x9c\xf65M', '\xd6\xe8\x02\xa3', 'M\xa5sc', '\x1b\x82|\x08', '\x87\xbd \xd7', '\xd3:f\xd7', '\x05\x81?\xc5']
>>> 

因此,我什至一次都没有收到原始消息abcd..!

为什么会这样??

我该如何克服这个?

帮我解决这个问题。

我在 Linux Mint 机器上使用 pyCrypto 库。

4

2 回答 2

6

ACR4 是流密码。它不会像您认为的那样加密。尝试这个:

en("abcd" * 16)

看看会发生什么。结果不会是相同字节的 16 倍,但与您在问题中尝试的相似。

如果要加密到相同的字节,则必须使用 ACR4 的新实例

e1 = ACR4.new('0123456789123456').encrypt
e2 = ACR4.new('0123456789123456').encrypt

assert e1("abcd") == e2("abcd")
于 2013-05-28T08:15:58.667 回答
3

RC4 是一种流密码,因此某些明文的加密形式取决于密码已经加密的内容。

>>> encrypted = [en('abcd') for i in range(4)]
>>> encrypted
['(h=\xd5', 'h \x8b\xe2', '\xa3\xb6\x16}', '\xe3\xb0\xda\xe3']
>>> decrypted = [de(x) for x in encrypted]
>>> decrypted
['abcd', 'abcd', 'abcd', 'abcd']

在进行加密/解密之前创建新的 RC4 对象,你会得到你期望的结果:

>>> a = ARC4.new('0123456789123456')
>>> b = ARC4.new('0123456789123456')
>>> de = b.decrypt
>>> en = a.encrypt
>>> al  = []
>>> for i in range(10):
...   al.append(en('abcd'))
... 
>>> gl = []
>>> for i in range(10):
...   gl.append(de(al[i]))
... 
>>> gl
['abcd', 'abcd', 'abcd', 'abcd', 'abcd', 'abcd', 'abcd', 'abcd', 'abcd', 'abcd']
于 2013-05-28T08:22:14.913 回答