0

我是使用 OpenSSL 库的新手,我无法使其输出与 python 的加密库的输出相匹配。下面是一个例子。

蟒蛇代码:

import hmac

secret = "asdf1234"
string = '{"request"}'

hmac.new(secret, string, hashlib.sha384).hexdigest()
    '92904f1b3c210a4fb19f476c19f24452717e85329aa9ffaba4a5fbe1111c2e3fa7f5a5fb35fdc58b3d158f5f886c3d02'

OpenSSL:

echo -n {"request"} | openssl dgst -sha384 -hmac asdf1234 -hex

(stdin)= 4c3d525b8a7095b9063a3bd974e56f0a5872399365912297d6ee18e400d2b55d0142395ba5fb4f33655ceca209ba9570

我究竟做错了什么?任一实现是否正确?

4

1 回答 1

1

为了匹配 openssl 输出,Python 字符串应该是'{request}'而不是'{"request"}'.

import hmac
import hashlib
secret = "asdf1234"
string = '{request}'

hmac.new(secret, string, hashlib.sha384).hexdigest()

产量

'4c3d525b8a7095b9063a3bd974e56f0a5872399365912297d6ee18e400d2b55d0142395ba5fb4f33655ceca209ba9570'

或者,如果您希望 openssl 命令与 Python 输出匹配,请使用

echo -n '{"request"}' | openssl dgst -sha384 -hmac asdf1234 -hex

产生

(stdin)= 92904f1b3c210a4fb19f476c19f24452717e85329aa9ffaba4a5fbe1111c2e3fa7f5a5fb35fdc58b3d158f5f886c3d02

毕竟,输入必须匹配,输出才有机会匹配:

% echo -n {"request"}
{request}

>>> print('{"request"}')
{"request"}
于 2014-10-18T23:08:26.067 回答