11

在 Erlang 中计算 HMAC-SHA1 的任何示例或库?

我尝试了 Crypto Module,但显然不完全匹配。有什么例子吗?

4

3 回答 3

22

为了扩展上一个答案,这里是 Python 中的 hmac 模块,它使用 SHA-1 算法,键为“hello”,消息为“world”:

>>> import hashlib
>>> import hmac
>>> hmac.HMAC(key='hello', msg='world', digestmod=hashlib.sha1).hexdigest()
'8a3a84bcd0d0065e97f175d370447c7d02e00973'

这是 Erlang 中的等价物。我会使用一种更有效的方法将二进制 MAC 转换为典型代码中的十六进制摘要,但为了简洁起见,我使用了这个:

1> crypto:start().
ok
2> <<Mac:160/integer>> = crypto:hmac(sha, <<"hello">>, <<"world">>).
<<138,58,132,188,208,208,6,94,151,241,117,211,112,68,124,
  125,2,224,9,115>>
3> lists:flatten(io_lib:format("~40.16.0b", [Mac])). 
"8a3a84bcd0d0065e97f175d370447c7d02e00973"
于 2010-11-17T07:34:54.430 回答
2

crypto 模块中的 sha_mac 函数是 HMAC-SHA1:

http://www.erlang.org/doc/man/crypto.html#sha_mac-2

它可能不匹配的原因是因为您可能将它与“hexdigest”进行比较,而不是原始摘要数据。

于 2010-11-16T11:49:17.763 回答
0
string:to_lower(lists:flatten([[integer_to_list(N, 16) || <<N:4>> <= crypto:sha_mac("hello", "world")]])).
于 2014-01-14T04:32:37.987 回答