我正在使用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,而無需用戶每次都必須授予對應用程序的訪問權限以生成請求令牌。
我還要提到http://stackoverflow.com/a/14693714/870667 URL傳遞有效Magento的資源URL。您正在連接備用端口,這是我遇到的問題,因爲在計算簽名時,Magento沒有考慮到這一點。 – 2013-12-22 21:30:20