2014-11-21 65 views
1

试图与Etsy的API来request_login但似乎没有任何工作....Etsy的API使用ColdFusion

https://openapi.etsy.com/v2/oauth/request_token?oauth_consumer_key=a93ays32uckifw3k0lrsfy2n&oauth_nonce=82asXUrVrwV&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1416562333&oauth_version=1.0&oauth_signature=mBhVKblbSBes1f3AkvaJmjJSJ24=

oauth_consumer_key = a93ays32uckifw3k0lrsfy2n 
oauth_nonce = 82asXUrVrwV 
oauth_signature_method = HMAC-SHA1 
oauth_timestamp = 1416562333 
oauth_version = 1.0 
oauth_signature = mBhVKblbSBes1f3AkvaJmjJSJ24= 

请建议如何进行

我想下面的代码

<cfset tc = CreateObject("java", "java.util.Date").getTime()> 
<cfset otimeStamp = Int(tc/1000)> 

<cfset iMin = 0> 
<cfset iMax = CreateObject("java","java.lang.Integer").MAX_VALUE> 
<cfset sToEncode = otimeStamp & RandRange(iMin, iMax)> 
<cfset onounce = Hash(sToEncode, "SHA")/> 

<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("a93ays32uckifw3k0lrsfy2n", "GET&https%3A%2F%2Fopenapi.etsy.com%2Fv2%2Foauth%2Frequest_token&oauth_consumer_key%3Da93ays32uckifw3k0lrsfy2n%26oauth_nonce%3D#onounce#%26oauth_signature_method%3DHMAC-SHA1%26oauth_timestamp%3D#otimeStamp#%26oauth_version%3D1.0")> 
<cfset osign = toString(tobase64(result))> 

<cfhttp url="https://openapi.etsy.com/v2/oauth/request_token?oauth_consumer_key=a93ays32uckifw3k0lrsfy2n&oauth_nonce=#onounce#&oauth_signature_method=HMAC-SHA1&oauth_timestamp=#otimeStamp#&oauth_version=1.0&oauth_signature=#osign#"> 
     <cfhttpparam type="header" name="shop_id" value="cfdevshop"> 
     <cfhttpparam type="header" name="GData-Version" value="3"> 
</cfhttp> 
<cfdump var="#cfhttp#"> 
+0

你能告诉我们一些代码和API Etsy的提供适当的文档链接? – 2014-11-21 12:54:59

+0

https://www.etsy.com/developers/documentation/getting_started/oauth – Rik 2014-11-21 13:17:37

+0

到目前为止,您使用了哪些代码来尝试此操作? – haxtbh 2014-11-21 13:18:09

回答

1

做Etsy的OAuth认证成功采用这种封装形式 http://oauthconsumer.riaforge.org/

+0

我想知道是否可以发布任何示例代码,并完成请求并使用auth令牌回叫您的应用程序。我遵循了上面你做的一些事情,但是我被etsy困住了,并没有让我回到我的网站上。 – steve 2014-12-01 16:51:02

+0

嗨史蒂夫,上面的代码有很多变化,但是当你想在你的网站中重定向时,你将不得不在你想要重定向的地方添加另一个带有值(url)的参数oauth_callback。 – Rik 2014-12-05 09:44:12

+0

嗨,谢谢。我最终在他的博客上发现了一个twillio的例子ben nadel。我花了几个小时把它撕下来并从中学习,并且能够为etsy oauth创建一个简单的界面并开始提取feed。 – steve 2014-12-05 19:55:25

1

你的问题在于时间戳。您传递的时间戳不正确。您应该在几秒钟内传递时间戳值。您可以按以下方法计算时间戳:

<cfset dateObj = now() /> 
<cfset timestamp = dateObj.getTime() /> 
<cfset timestampInSeconds = timestamp/1000 /> 
<cfdump var="#timestampInSeconds#"><cfabort> 

时间戳应该是+/- 5分钟内找到你的系统当前的时间戳。
我已经使用了所有你在这里提供的参数在我的代码如下:

<cfhttp url="https://openapi.etsy.com/v2/oauth/request_token"> 
    <cfhttpparam type="header" name="GData-Version" value="3"> 
    <cfhttpparam type="url" name="oauth_signature" value="mBhVKblbSBes1f3AkvaJmjJSJ24=" > 
    <cfhttpparam type="url" name="oauth_version" value="1.0" > 
    <cfhttpparam type="url" name="oauth_timestamp" value="#timestampInSeconds#" > 
    <cfhttpparam type="url" name="oauth_signature_method" value="HMAC-SHA1" > 
    <cfhttpparam type="url" name="oauth_nonce" value="8225XUrVrwV" > 
    <cfhttpparam type="url" name="oauth_consumer_key" value="a93ays32uckifw3k0lrsfy2n" > 
</cfhttp> 
<cfdump var="#cfhttp#"><cfabort> 

我想您所提供的虚拟值(这是一件好事)。你可以在截图中看到我得到不同的错误(无效的oauth签名错误)。如果你提供正确的价值观,我认为你很好去。
enter image description here

getTime()方法是Date class的java方法。你可以看到它是如何工作的:

<cfset dateObj = createObject("java","java.util.Date") /> 
<cfset timeStamp = dateObj.getTime() /> 
<cfdump var="#timeStamp#"><cfabort> 
+0

嗨tushar,请参阅我更新的代码,我发现一些代码来生成Time_stamp,oauth_nounce和oauth_signature,在更新的代码中使用,但仍然收到错误“oauth_problem = signature_invalid”。请提出建议 – Rik 2014-11-24 14:56:07