我正在为magento REST API的这个痛苦问题而死。 我可以使用REST API获取订单。只有当我尝试使用POST方法创建产品时,才会出现以下错误。 我试过的PHP代码如下所示。
function upload_to_store($id=null,$product_data=null)
{
/**
* Example of simple product POST using Admin account via Magento REST API. OAuth authorization is used
*/
$callbackUrl = site_url() . "admin_products/upload_to_store/".$id;
$temporaryCredentialsRequestUrl = "url" . urlencode($callbackUrl);
$adminAuthorizationUrl = 'oauth_authorize';
$accessTokenRequestUrl = 'token url';
$apiUrl = 'api url';
$consumerKey = '';
$consumerSecret = '';
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";
$productData = json_encode(array(
'type_id' => 'simple',
'attribute_set_id' => 4,
'sku' => $product_data['sku'],
'weight' => $product_data['weight'],
'status' => 1,
'visibility' => 4,
'name' => $product_data['name'],
'description' => $product_data['description'],
'short_description' => $product_data['short_description'],
'price' => $product_data['price'],
'tax_class_id' => 0,
));
$oauthClient->disableRedirects();
$headers = array('Content-Type' => 'application/json', 'Content_Type' => 'application/json');
$oauthClient->fetch($resourceUrl, $productData, OAUTH_HTTP_METHOD_POST, $headers);
$response = $oauthClient->getLastResponseInfo();
if (isset($response['url'])) {
header('Location: ' . $response['url']);
}
}
return true;
} catch (OAuthException $e) {
print_r($e);
}}
我收到此错误:
OAuthException: Invalid auth/bad request (got a 400, expected HTTP/1.1 20X or a redirect)
我怎样摆脱这个? 提前谢谢。
答案 0 :(得分:0)
对于任何遇到“无效的身份验证/错误请求(获得400,预期的HTTP / 1.1 20X或重定向)”的人在执行POST时出现错误而GET工作正常,我发现通常它与(选定的)REST属性。特别是400错误。
如果上面的POST有创建产品,请转到系统 - > Web服务 - > REST属性 - >选择管理员并确保已选择目录,产品和以下(写入)可能性。按保存,然后重试。如果您遵循http://devdocs.magento.com/guides/m1x/api/rest/introduction.html
中的文档,大多数时候它会在此之后正常工作