我正在翻译一个用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”));
好玩的东西.很高兴知道.
解决方法:
我认为你需要它反过来. “Dummy String”不是十六进制中的有效数字.你可以通知它:
>>> binascii.hexlify('Dummy String')
'44756d6d7920537472696e67'
但不能完全消除它. unhexlify采用十六进制的字符串并将其转换为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”和“=”让我非常肯定它是正确的.