2

当我尝试使用 iPhone 访问 REST API 时,我在 URL 中传递了以下参数并使用了POSTGET这两种方法,但它显示Access Denied

oauth_version="1.0", 
oauth_signature_method="HMAC-SHA1",
oauth_nonce="B0dlzkfMWCAn0TJ", 
oauth_timestamp="1366280813",
oauth_consumer_key="klkjylsiozbv6vfdsqtuheqo3kmqqzv2",
oauth_token="t9pefrwylmg7webyepsqepotlhzbytkp",
oauth_signature="NeOwbCLUPbIyF9ErnHoFQOl9%2Bwo%3D"

我曾使用 Firefox 和 Chrome 可用的 REST 客户端插件,REST API 使用 REST 客户端插件运行良好,但在 iPhone 中无法访问。

我正在为 oauth_timestamp、oauth_signature 和 oauth_nonce 生成一个随机值,然后 REST API 也正在显示Access Denied

请提供建议。

4

2 回答 2

1

//这里 final_sign 是从以下过程生成的签名。

$nonce = substr(md5(uniqid('nonce_', true)),0,16);
$temprealm="http://magentohost/api/rest/products";
$realm=urlencode($temprealm);
$oauth_version="1.0";
$oauth_signature_method="HMAC-SHA1";
$oauth_consumer_key="dfddfgdgdfgddf6qgygmyvw7e3";
$oauth_access_token="fdgdfgfdgdfg357gimpdnuejvcbtk51ni";
$oauth_method="GET";
$oauth_timestamp=time();
$algo="sha1";
$key="sb88hfdihyg25ipt1by559yzbj2m3861&s7uhaheu8nrx961oxg6uc3os4zgyc2tm"; //consumer secret & token secret //Both are used in generate signature
$data="oauth_consumer_key=".$oauth_consumer_key."&oauth_nonce=".$nonce."&oauth_signature_method=".$oauth_signature_method."&oauth_timestamp=".$oauth_timestamp."&oauth_token=".$oauth_access_token."&oauth_version=".$oauth_version;

$send_data=$oauth_method."&".$realm."&".urlencode($data);
$sign=hash_hmac($algo,$send_data,$key,1); // consumer key and token secrat used here
$fin_sign=base64_encode($sign);

echo $fin_sign;
于 2013-05-17T09:29:12.070 回答
0

根据您的问题,我了解到您对签名nonce使用随机值。后者会很好,但随机签名会导致接收者不相信你是合法的客户。

所以,实际上,你得到了你请求的响应 (;-))。但这并不能解决您的问题。

您必须为 magento 系统生成一个有效的签名

于 2013-04-19T09:11:06.827 回答