2013-03-27 73 views
3

我正在使用Magento 1.7.0.2版并尝试使用OAuth集成使用Magento Rest API。 我已经安装的OAuth和以下是我已经把在Magento的根目录下的代码片段,我通过键入http://x.x.x.x:5009/oauth_customer.php无法使用Magento REST API使用OAuth

$callbackUrl = "http://x.x.x.x:5009/oauth_customer.php"; 
$temporaryCredentialsRequestUrl = "http://x.x.x.x:5009/oauth/initiate?oauth_callback=" . urlencode($callbackUrl); 
$adminAuthorizationUrl = 'http://x.x.x.x:5009/oauth/authorize'; 
$accessTokenRequestUrl = "http://x.x.x.x:5009/oauth/token"; 
$apiUrl = "http://x.x.x.x:5009/api/rest"; 
$consumerKey = 'yourconsumerkey'; 
$consumerSecret = 'yourconsumersecret'; 

session_start(); 
if (!isset($_GET['oauth_token']) && isset($_SESSION['state']) && $_SESSION['state'] == 1) { 
    $_SESSION['state'] = 0; 
} 
try { 
$authType = ($_SESSION['state'] == 2) ? OAUTH_AUTH_TYPE_AUTHORIZATION : OAUTH_AUTH_TYPE_URI; 
$oauthClient = new OAuth($consumerKey, $consumerSecret, OAUTH_SIG_METHOD_HMACSHA1, $authType); 
$oauthClient->enableDebug(); 

if (!isset($_GET['oauth_token']) && !$_SESSION['state']) { 
    $requestToken = $oauthClient->getRequestToken($temporaryCredentialsRequestUrl); 
    $_SESSION['secret'] = $requestToken['oauth_token_secret']; 
    $_SESSION['state'] = 1; 
    header('Location: ' . $adminAuthorizationUrl . '?oauth_token=' . $requestToken['oauth_token']); 
    exit; 
} else if ($_SESSION['state'] == 1) { 
    $oauthClient->setToken($_GET['oauth_token'], $_SESSION['secret']); 
    $accessToken = $oauthClient->getAccessToken($accessTokenRequestUrl); 
    $_SESSION['state'] = 2; 
    $_SESSION['token'] = $accessToken['oauth_token']; 
    $_SESSION['secret'] = $accessToken['oauth_token_secret']; 
    header('Location: ' . $callbackUrl); 
    exit; 
} else { 
    $oauthClient->setToken($_SESSION['token'], $_SESSION['secret']); 
    $resourceUrl = "$apiUrl/products"; 
    $oauthClient->fetch($resourceUrl); 
    $productsList = json_decode($oauthClient->getLastResponse()); 
    print_r($productsList); 
} 
} catch (OAuthException $e) { 
    print_r($e); 
} 

http://x.x.x.x:5009是IP地址后5009,其中5009运行它在网络浏览器的端口号指定。 当我们在浏览器中运行它,我总是得到下面的错误 - 无效的授权/错误的请求(有一个401,预计HTTP/1.1 20X或重定向) oauth_problem = signature_invalid & debug_sbs = Bya6oE4ujTEEFLVL6Mm04PqTA4g =

我我无法得到这份工作。

注 - 我已生成使用者密钥和密钥。不确定如何通过客户访问REST API资源来创建用户凭证,以适应上述脚本。 另外我想知道,如果我们可以在任何非magento网站上使用oAuth集成编程方式使用magento apis,而无需用户每次都必须授予对应用程序的访问权限以生成请求令牌。

+0

我还要提到http://stackoverflow.com/a/14693714/870667 URL传递有效Magento的资源URL。您正在连接备用端口,这是我遇到的问题,因为在计算签名时,Magento没有考虑到这一点。 – 2013-12-22 21:30:20

回答