当前位置: 首页 > 面试题库 >

HMAC-SHA1:如何在Java中正确执行?

麻书
2023-03-14
问题内容

我使用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