Magento OAuthException:无效的身份验证/错误请求得到400

时间:2016-02-10 09:03:34

标签: rest magento oauth

我正在为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)

我怎样摆脱这个? 提前谢谢。

1 个答案:

答案 0 :(得分:0)

你有没有解决这个问题?

对于任何遇到“无效的身份验证/错误请求(获得400,预期的HTTP / 1.1 20X或重定向)”的人在执行POST时出现错误而GET工作正常,我发现通常它与(选定的)REST属性。特别是400错误。

如果上面的POST有创建产品,请转到系统 - > Web服务 - > REST属性 - >选择管理员并确保已选择目录,产品和以下(写入)可能性。按保存,然后重试。如果您遵循http://devdocs.magento.com/guides/m1x/api/rest/introduction.html

中的文档,大多数时候它会在此之后正常工作