使用Java计算ColdFusion中的HMAC-SHA256摘要

时间:2009-06-04 16:02:41

标签: java encryption coldfusion hmac

我们正在尝试计算ColdFusion中的HMAC-SHA256摘要,我们正在使用HMAC CFC,但在一种情况下,与使用不同语言生成的摘要相比,它产生的摘要结果不同 - 使用了相同的数据Ruby& PHP并获得预期的结果。我也尝试了它所基于的CF_HMAC自定义标签并获得相同的结果。

据我所知,CF8 encrypt()支持HMAC-SHA256,但它仅在Enterprise(我们没有)中可用,甚至在开发人员版本中也无法供我测试。

所以我的问题是我可以通过从CF访问Java来实现吗?

2 个答案:

答案 0 :(得分:11)

这就是我最终做的事情:

secret = createObject('java', 'javax.crypto.spec.SecretKeySpec' ).Init(my_key.GetBytes(), 'HmacSHA256');
mac = createObject('java', "javax.crypto.Mac");
mac = mac.getInstance("HmacSHA256");
mac.init(secret);
digest = mac.doFinal(my_data.GetBytes());

这为您提供了字节数组,然后您可以将其转换为字符串。

答案 1 :(得分:0)

这是一个使用不同输入/输出格式的DEfusion答案的例子。我的密钥是十六进制,我的数据是低的ascii(所以UTF-8会这样做),我需要base64输出,所以我将相应的格式参数传递给BinaryDecode和CharsetDecode:

<cfset keybytes = BinaryDecode(SECRET_KEY, "Hex")>
<cfset databytes = CharsetDecode(data, "UTF-8")>
<cfset secret = createObject("java", "javax.crypto.spec.SecretKeySpec").Init(keybytes,"HmacSHA256")>
<cfset mac = createObject("java", "javax.crypto.Mac")>
<cfset mac = mac.getInstance("HmacSHA256")>
<cfset mac.init(secret)>
<cfset digest = mac.doFinal(databytes)>
<cfset result = BinaryEncode(digest, "Base64")>