简单示例aes256 crypt
问题描述:
为什么这个示例不起作用?简单示例aes256 crypt
from Crypto.Cipher import AES x = AES.new("sdsfdsafsadfdsafasdfdsarwe876539", AES.MODE_CBC, "2324234342342342") print x.decrypt(x.encrypt('abcdfghkbhgjrdfs'))
答
因为x
是一个有状态的对象。用它来加密一个字符串会改变状态;再次使用它会产生不同的输出。
使用新的AES加密具有相同的初始状态,你加密过的时候:
>>> from Crypto.Cipher import AES
>>> key= "sdsfdsafsadfdsafasdfdsarwe876539"
>>> prefix= '2324234342342342'
>>> AES.new(key, AES.MODE_CBC, prefix).encrypt('abcdfghkbhgjrdfs')
'\xf4\xd9\xd1B8\xc1\x16\xe1\x9b~\xd0\x99\x1c\xf8\xdfn'
>>> AES.new(key, AES.MODE_CBC, prefix).decrypt(_)
'abcdfghkbhgjrdfs'
什么不起作用? – 2011-04-25 12:28:56