Coldfusion HMAC-SHA1加密

时间:2012-02-08 01:49:36

标签: encryption coldfusion coldfusion-9 hmacsha1

此处有一个示例HMAC-SHA1可以在javascript中运行

http://jssha.sourceforge.net/

要加密的文本

vibaHBXwUXFqVSg- + kTrqYJZEJkbVeqLc = bo.LlXGET12505351831husu9039http://api.tineye.com/rest/search/image_url=http%3a%2f%2ftineye.com%2fimages%2ftineye_logo_big.png&限制= 30&安培;偏移量= 10 < / p>

关键

vibaHBXwUXFqVSg- + kTrqYJZEJkbVeqLc = bo.LlX

输出

9e734661c9e8b6dc9b6b4b3def9769c00e8843b8

问题

但是我不能复制Coldfusion中的输出。我正在使用之前Stackoverflow.com问题中的函数

<cffunction name="hmacEncrypt" returntype="binary" access="public" output="false">
   <cfargument name="signKey" type="string" required="true" />
   <cfargument name="signMessage" type="string" required="true" />


   <cfset var jMsg = JavaCast("string",arguments.signMessage).getBytes("iso-8859-1") />
   <cfset var jKey = JavaCast("string",arguments.signKey).getBytes("iso-8859-1") />

   <cfset var key = createObject("java","javax.crypto.spec.SecretKeySpec") />
   <cfset var mac = createObject("java","javax.crypto.Mac") />

   <cfset key = key.init(jKey,"HmacSHA1") />

   <cfset mac = mac.getInstance(key.getAlgorithm()) />
   <cfset mac.init(key) />
   <cfset mac.update(jMsg) />

   <cfreturn mac.doFinal() />
</cffunction>

<cfset result = hmacEncrypt("vibaHBXwUXFqVSg-+kTrqYJZEJkbVeqLc=bo.LlX", "vibaHBXwUXFqVSg-+kTrqYJZEJkbVeqLc=bo.LlXGET12505351831husu9039http://api.tineye.com/rest/search/image_url=http%3a%2f%2ftineye.com%2fimages%2ftineye_logo_big.png&limit=30&offset=10")>

<cfset x1 = toString(tobase64(result))>

返回

nnNGYcnottyba0s975dpwA6IQ7g =

任何帮助表示感谢。

2 个答案:

答案 0 :(得分:6)

<cfset x1 = toString(tobase64(result))>

另一个函数是返回hex,而不是base64。除此之外它似乎对我来说很好:

 <cfset x1 = binaryEncode(result, "hex")>

答案 1 :(得分:3)

线索在您预期的输出字符串中:它只包含数字和小写字母。如果仔细观察,所有字母都在a-f范围内。因此极有可能是十六进制字符串。

示例代码的最后一行将结果编码为base64,而不是十六进制。您可以通过将最后一行更改为此来将结果编码为十六进制:

<cfset x1 = binaryEncode(result,"hex")>

我运行了修改后的代码并获得了

9E734661C9E8B6DC9B6B4B3DEF9769C00E8843B8

这是您期望的字符串的大写版本。