[英]Error while using REST api in magento
我已经使用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
任何人都可以对此有所了解吗?
由于无法在xampp Windows中安装oauth,因此我将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"}]}}
我究竟做错了什么?
首先,转到magento管理面板, System->Webservice->RESt Roles->Guest->Resources Access ->SET ALL
同样,转到System->Webservice->RESt Attribute->Guest->Resources Access ->SET ALL
然后在Web浏览器中点击此URL http://****/chanchal/magento/api/rest/products
,并检查显示的错误。
据我说,它必须以xml
格式在您的网站中显示产品。
请告诉我..
编辑:我刚才配置了一个本地主机,并得到此输出,请参阅屏幕快照。 确保您的magento中有产品。
同样地,按照上述步骤进行管理,客户然后从管理面板创建Ouath使用者,为Mozilla Firefox安装RESTClient并按照此处
这些设置步骤是必需的。此链接可能会为您提供帮助。
认证端点
1. /oauth/initiate
此端点用于检索请求令牌。
2. /oauth/authorize
此端点用于用户授权(客户)。
3. /admin/oauth_authorize
此端点用于用户授权(Admin)。
4. /oauth/token
此端点用于检索访问令牌。
如果您有任何问题,请告诉我。
祝你好运
稍加修改代码即可轻松解决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 ,
更改此行从
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标准提供更好的解决方案。 这样,核心文件将保持完整。
我遇到了同样的问题,苦苦挣扎了一周,但是尝试用支持ouath安装新版本的xammp或wamp。更好的解决方案是,我安装了Ammps 1.9,并在php5.4中解决了oauth的扩展问题,但仍要确保您选择支持扩展名oauth的适当php(php5.4)
对于安装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
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.