我已使用XAMPP
在我的系统中本地设置了magento我在根目录中创建了一个名为dm.php的文件,内容为
<?php
/**
* Example of products list retrieve using Customer account via Magento REST API. OAuth authorization is used
*/
$callbackUrl = "http://localhost/dm.php";
$temporaryCredentialsRequestUrl = "http://localhost/mage2/oauth/initiate?oauth_callback=" . urlencode($callbackUrl);
$adminAuthorizationUrl = 'http://localhost/mage2/oauth/authorize';
$accessTokenRequestUrl = 'http://localhost/mage2/oauth/token';
$apiUrl = 'http://localhost/mage2/api/rest';
$consumerKey = 'enhksf7u33p3snubewb6zcq0z9c63bvv';
$consumerSecret = 'p7e835cdcxofokeep749jgzz4l1e306p';
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);
}
但是这给了我以下错误
Fatal error: Class 'OAuth' not found in D:\Webserver\xampp\htdocs\dm.php on line 19
任何人都可以对此有所了解 感谢
由于oauth无法在xampp窗口中安装,因此我将dm.php文件的内容更改为此。
<?php
$ch = curl_init('http://localhost/mage2/api/rest/customers');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$customers = curl_exec($ch);
echo $customers;
?>
现在我收到这样的错误
{"messages":{"error":[{"code":403,"message":"Access denied"}]}}
我做错了什么?
答案 0 :(得分:12)
首先
转到magento管理面板System->Webservice->RESt Roles->Guest->Resources Access ->SET ALL
同样转到System->Webservice->RESt Attribute->Guest->Resources Access ->SET ALL
然后在网络浏览器中点击此网址http://****/chanchal/magento/api/rest/products
并检查它显示的错误....
据我所知,它必须以xml
格式在您的网站上展示产品。
请告诉我..
编辑: 我刚刚配置了一个localhost并得到了这个输出参考截图。确保您的magento中有产品。
同样按照上述步骤进行管理,然后客户从管理面板创建一个Ouath消费者,为Mozilla Firefox安装RESTClient并按照Here
这些步骤对于设置是必要的......链接可能对您有帮助..
身份验证端点
1. /oauth/initiate
- 此端点用于检索请求令牌。
2. /oauth/authorize
- 此端点用于用户授权(客户)。
3. /admin/oauth_authorize
- 此端点用于用户授权(管理员)。
4. /oauth/token
- 此端点用于检索访问令牌。
如果您有任何问题,请告诉我。
祝你好运
答案 1 :(得分:2)
一些代码修改可以轻松解决此错误403 forbidden
。
magento引擎所做的是它使用默认的guest
用户来提供对REST api方法的访问。来宾用户没有太多权力,所以更好地改变magento的这个功能。有两种方法可以做到这一点:
1)快速和脏修复:
在文件 /app/code/core/Mage/Api2/Model/Auth.php 中,更改以下值:
DEFAULT_USER_TYPE = 'guest'
至DEFAULT_USER_TYPE = 'admin'
。
在文件
/app/code/core/Mage/Api2/Model/Auth/Adapter.php 中,
从<更改此行br /> return (object) array('type' => Mage_Api2_Model_Auth::DEFAULT_USER_TYPE, 'id' => null);
对此:
return (object) array('type' => Mage_Api2_Model_Auth::DEFAULT_USER_TYPE, 'id' => '1');
这样,身份验证系统就不会被破坏。
2)正确和长期修复:
使用magento覆盖机制覆盖这两个功能,以便根据magento标准获得更好的解决方案。这样核心文件就完好无损了。
答案 2 :(得分:0)
答案 3 :(得分:0)
我遇到了同样的问题并且正在努力一周,但只是尝试将新版本的xammp或wamp支持ouath。更好的解决方案是,我安装了Ammps 1.9并且在php5.4中我解决了oauth的扩展但仍然确保你选择适当的php for extension oauth支持(php5.4)
答案 4 :(得分:0)
安装Oauth:http://www.magentocommerce.com/api/rest/authentication/oauth_authentication.html
为Oauth安装PHP扩展: 1.下载php_oauth.dll文件并将其添加到C:\ xampp \ php \ ext \下 2.在php.ini中添加[PHP_OAUTH] extension = php_oauth.dll