2013-03-27 76 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

回答