我使用Java中的以下代码使用HMAC-SHA1哈希一些值:
public static String hmacSha1(String value, String key) {
try {
// Get an hmac_sha1 key from the raw key bytes
byte[] keyBytes = key.getBytes();
SecretKeySpec signingKey = new SecretKeySpec(keyBytes, "HmacSHA1");
// Get an hmac_sha1 Mac instance and initialize with the signing key
Mac mac = Mac.getInstance("HmacSHA1");
mac.init(signingKey);
// Compute the hmac on input data bytes
byte[] rawHmac = mac.doFinal(value.getBytes());
// Convert raw bytes to Hex
byte[] hexBytes = new Hex().encode(rawHmac);
// Covert array of Hex bytes to a String
return new String(hexBytes, "UTF-8");
} catch (Exception e) {
throw new RuntimeException(e);
}
}
Hex()
属于 org.apache.commons.codec
在PHP中,有一个类似的函数可用hash_hmac(algorithm, data, key)
来比较Java实现返回的值。
因此,首先尝试是:
hash_hmac("sha1", "helloworld", "mykey") // PHP
返回: 74ae5a4a3d9996d5918defc2c3d475471bbf59ac
我的Java函数74ae5a4a3d9996d5918defc2c3d475471bbf59ac
也会返回。
好的,看来可行。然后,我尝试使用一个更复杂的键:
hash_hmac("sha1", "helloworld", "PRIE7$oG2uS-Yf17kEnUEpi5hvW/#AFo") // PHP
返回: e98bcc5c5be6f11dc582ae55f520d1ec4ae29f7a
这次,我的Java展示返回了: c19fccf57c613f1868dd22d586f9571cf6412cd0
我的PHP代码返回的哈希值不等于我的Java函数返回的值,而且我找不到原因。
有小费吗?
在您的PHP方面,请在键周围使用单引号,以使该$
字符不会被视为变量引用。即
hash_hmac("sha1", "helloworld", 'PRIE7$oG2uS-Yf17kEnUEpi5hvW/#AFo')
否则,您真正得到的键是PRIE7-Yf17kEnUEpi5hvW/#AFo
(假设$oG2uS
未定义变量)。
问题内容: 我从http://tools.ietf.org/html/rfc6238借用了HMAC- SHA1 Java代码,并稍加修改以对其进行硬编码,以使用一个具有已知输出的已知密钥/消息对。 然后,我尝试在Python中编写相同的代码以验证结果,但是在Python和Java中获得了不同的值。 已知Java值很好。 Java代码: Python代码: 运行Java的结果: 运行Python的结
问题内容: 我从http://tools.ietf.org/html/rfc6238借用了HMAC- SHA1 Java代码,并稍加修改以对其进行硬编码,以使用一个具有已知输出的已知密钥/消息对。 然后,我尝试在Python中编写相同的代码以验证结果,但是在Python和Java中获得了不同的值。 Java值众所周知是好的。 Java代码: Python代码: 运行Java的结果: 运行Pytho
问题内容: 我正在尝试使用网站的OAuth,该网站要求签名方法仅是“ HMAC-SHA1”。 我想知道如何在Python中实现此功能? 问题答案: 假单胞菌: 签名错误通常驻留在基本字符串中,请确保您理解这一点(如OAuth1.0规范在此处所述:http://tools.ietf.org/html/draft-hammer- oauth-10#section-3.4 。 1)。 以下输入用于生成签
问题内容: 我正在寻找一个等效于此php调用的Java: 我使用java.crypto.Mac尝试了此操作,但两者不同意: 键=“ secret”和test =“ test”的输出似乎不匹配。 问题答案: 实际上,他们确实同意。 正如Hans Doggen已经指出的那样,除非将raw输出参数设置为true,否则PHP使用十六进制表示法来输出消息摘要。 如果要在Java中使用相同的符号,可以使用类似
我的任务是将一些现有的node.js代码转换为Java。我想我已经在路上了,但我现在有点卡住了。方法的输出似乎不匹配。 我所做的是基于查询字符串创建SHA-1签名。这个查询字符串包含一些与查询相关的数据(与这个问题无关)和一个API键。 重要 null SHA-1 mac在Java中的初始化如下: 接下来,node.js程序更新hmac(参数如上所列): 我在Java中这样复制了它(参数等于nod