我正在翻译一个用PHP编写的认证库。这是所有遗留代码,原始开发人员早已不复存在。他们使用PHP的'pack'命令使用'H'标志将字符串转换为十六进制。 PHP的documentation将其描述为“Hex string,high nibble first”。我读了另一个问题(Python equivalent of php pack)建议使用binascii.unhexlify(),但每当我传入一个非十六进制字符时就会抱怨。
所以我的问题是PHP包函数对非十六进制字符的作用是什么?它是否会将它们丢弃,或者是否有执行翻译的额外步骤。 Python中有比binascii.unhexlify更好的方法吗?
所以打包'H *'
php -r 'print pack("H*", md5("Dummy String"));'
返回
??????=?PW??
在python中:
secret = binascii.unhexlify( "Dummy String" )
TypeError: Non-hexadecimal digit found
感谢您的帮助。
[编辑]
所以DJV基本上是正确的。我需要先将值转换为md5,然而这就是它的有趣之处。在python中,md5库通过'digest'方法返回二进制数据。
在我的情况下,我可以跳过所有的binascii调用,只需使用
md5.md5('Dummy String').digest()
PHP中的相同内容:
pack(“H *”,md5(“Dummy String”));
有趣的东西。很高兴知道。答案 0 :(得分:3)
我认为你需要反过来。 "Dummy String"
中的hex
不是有效号码。你可以hexlify
:
>>> binascii.hexlify('Dummy String')
'44756d6d7920537472696e67'
但不是unhexlify
。 unhexlify
在hex
中使用一个字符串并将其转换为ASCII代码:
>>> binascii.unhexlify('44756d6d7920537472696e67')
'Dummy String'
您需要的是md5
字符串(在我们的例子中是"Dummy String"
)和unhexlify
它的哈希:
import binascii
import hashlib
the_hash = hashlib.md5('Dummy String').hexdigest()
print the_hash
the_unhex = binascii.unhexlify(the_hash)
print the_unhex
产生散列和未完成的散列:
ec041da9f891c09b3d1617ba5057b3f5
ЛLЬ-ю?=¦PWЁУ
注意:虽然输出看起来并不像你的那样 - " ?????? =?PW ??"," PW"和" ="两者都让我非常肯定它是正确的。
的更多信息