我想向学生们展示MD5碰撞两个整数"消息"给定here。这是我对Python 2.7的原始演示:
from hashlib import md5
m1 = "d131dd02c5e6eec4693d9a0698aff95c2fcab58712467eab4004583eb8fb7f8955ad340609f4b30283e488832571415a085125e8f7cdc99fd91dbdf280373c5bd8823e3156348f5bae6dacd436c919c6dd53e2b487da03fd02396306d248cda0e99f33420f577ee8ce54b67080a80d1ec69821bcb6a8839396f9652b6ff72a70"
m2 = "d131dd02c5e6eec4693d9a0698aff95c2fcab50712467eab4004583eb8fb7f8955ad340609f4b30283e4888325f1415a085125e8f7cdc99fd91dbd7280373c5bd8823e3156348f5bae6dacd436c919c6dd53e23487da03fd02396306d248cda0e99f33420f577ee8ce54b67080280d1ec69821bcb6a8839396f965ab6ff72a70"
# differences ^ ^ ^ ^ ^ ^
print md5(m1.decode("hex")).hexdigest()
print md5(m2.decode("hex")).hexdigest()
正如预期的那样,它会打印两次79054025255fb1a26e4bc422aef54eb4
。
现在,当我尝试将最后两行转换为Python 3.5时:
print(md5(int(m1, 16)).hexdigest())
print(md5(int(m2, 16)).hexdigest())
我得到的只是TypeError: object supporting the buffer API required
消息。方法decode
不再适用于Python 3,但我不确定如上所述将int(m, base)
替换为{1}}是个好主意。可能存在问题,而不是哈希函数API?
答案 0 :(得分:5)
在Python 2中,将字符串解码为十六进制为您提供字节串,而不是整数。不要试图将十六进制字符串解释为整数。
使用binascii.unhexlify()
function将十六进制字符串转换为字节字符串:
from binascii import unhexlify
print(md5(unhexlify(m1)).hexdigest())
请注意,相同的代码也可以在Python 2中正常工作。
如果您仍想使用解码,请使用codecs.decode()
function:
import codecs
print(md5(codecs.decode(m1, 'hex')).hexdigest())
同样,相同的代码也适用于Python 2。