Php Amazon MWS错误签名不匹配

Php Amazon MWS错误签名不匹配,php,amazon-web-services,amazon-mws,Php,Amazon Web Services,Amazon Mws,我们正在尝试访问AmazonMWSAPI,但我们就是无法让它工作,我们不知道为什么。 这就是我们迄今为止所做的尝试: require_once('.config.inc.php'); $base_url = "https://mws.amazonservices.de/Products/2011-10-01"; $method = "POST"; $host = "mws.amazonservices.de"; $u

我们正在尝试访问AmazonMWSAPI,但我们就是无法让它工作,我们不知道为什么。 这就是我们迄今为止所做的尝试:

        require_once('.config.inc.php');
        $base_url = "https://mws.amazonservices.de/Products/2011-10-01";
        $method = "POST";
        $host = "mws.amazonservices.de";
        $uri = "/Products/2011-10-01";

        $params = array(
            'AWSAccessKeyId' => <our Key>,
            'Action' => "GetLowestOfferListingsForASIN",
            'SellerId' => <our ID>,
            'SignatureMethod' => "HmacSHA256",
            'SignatureVersion' => "2",
            'Timestamp'=> gmdate("Y-m-d\TH:i:s.\\0\\0\\0\\Z", time()), //tried this with time()+7200 since our server is 2 hours back but we also accessed mws to get the time used there
            'Version'=> "2011-10-01",
            'MarketplaceId' => <our MpID>,
            'ItemCondition' => 'new',
            'ASINList.ASIN.1' => B00NN8LSXY );

            // Sort the URL parameters
            $url_parts = array();
            foreach(array_keys($params) as $key)
            $url_parts[] = $key . "=" . str_replace('%7E', '~', rawurlencode($params[$key]));

            sort($url_parts);

            // Construct the string to sign
            $url_string = implode("&", $url_parts);
            $string_to_sign = "POST\nmws.amazonservices.de\n/Products/2011-10-01\n" . $url_string;

            // Sign the request
            $signature = hash_hmac("sha256", $string_to_sign, AWS_SECRET_ACCESS_KEY, TRUE);

            // Base64 encode the signature and make it URL safe
            $signature = urlencode(base64_encode($signature));

            $url = "https://mws.amazonservices.de/Products/2011-10-01" . '?' . $url_string . '&Signature=' . $signature;
            $ch = curl_init();
            curl_setopt($ch, CURLOPT_URL,$url);
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
            curl_setopt($ch, CURLOPT_TIMEOUT, 15);
            curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
            $response = curl_exec($ch);

            //$parsed_xml = simplexml_load_string($response);

        echo $response;
            //return ($parsed_xml);
require_once('.config.inc.php');
$base_url=”https://mws.amazonservices.de/Products/2011-10-01";
$method=“POST”;
$host=“mws.amazonservices.de”;
$uri=“/Products/2011-10-01”;
$params=数组(
'AWSAccessKeyId'=>,
“操作”=>“GetLowsTofferListingsForasin”,
'SellerId'=>,
“SignatureMethod”=>“HmacSHA256”,
'SignatureVersion'=>“2”,
'Timestamp'=>gmdate(“Y-m-d\TH:i:s.\\0\\0\\0\\Z”,time()),//尝试了time()+7200,因为我们的服务器返回了2小时,但我们也访问了mws以获取在那里使用的时间
“版本”=>“2011-10-01”,
'MarketplaceId'=>,
'ItemCondition'=>'new',
'ASINList.ASIN.1'=>B00NN8LSXY);
//对URL参数进行排序
$url_parts=array();
foreach(数组_键($params)作为$key)
$url\u parts[]=$key。"=" . str_replace('%7E','~',rawurlencode($params[$key]);
排序($url\u部分);
//构造要签名的字符串
$url\u string=内爆(&,$url\u部分);
$string_to_sign=“POST\nmws.amazonservices.de\n/Products/2011-10-01\n”$url_字符串;
//签署请求
$signature=hash_hmac(“sha256”,$string_to_sign,AWS_SECRET_ACCESS_KEY,TRUE);
//Base64对签名进行编码并使其URL安全
$signature=urlencode(base64_encode($signature));
$url=”https://mws.amazonservices.de/Products/2011-10-01" . '?' . $url_字符串。'&签名='$签名;
$ch=curl_init();
curl_setopt($ch,CURLOPT_URL,$URL);
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch,CURLOPT_超时,15);
curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,0);
$response=curl\u exec($ch);
//$parsed_xml=simplexml_load_string($response);
回音$应答;
//返回($parsed_xml);
在.config.inc.php文件中,我们添加了 所有的钥匙和ID+

define('APPLICATION_NAME', '<our Firm>');
define('APPLICATION_VERSION', '1.0');
define('应用程序名称','');
定义(‘应用程序_版本’、‘1.0’);
在我们做这些之前,我们在MWS Scratchpad中检查了所有内容,但似乎所有内容都在那里工作(在MWS.amazon.de上)

但我们仍然得到SignatureDesNotMatch错误代码

 <Message>The request signature we calculated does not match the signature you provided. Check your AWS Secret Access Key and signing method. Consult the service documentation for details.</Message>
我们计算的请求签名与您提供的签名不匹配。检查您的AWS秘密访问密钥和签名方法。有关详细信息,请参阅维修文档。
或此错误代码:

<Message>Request signature is for too far in the future. Timestamp date: 2015-05-23T04:54:38.000Z. Currently, 10 percent of requests that are more than 15 minutes in the future will be rejected.</Message>
请求签名在将来太远了。时间戳日期:2015-05-23T04:54:38.000Z。目前,未来超过15分钟的请求中有10%将被拒绝。

希望有人能帮助我们阅读关于这方面的所有其他帖子和开发人员指南-似乎没有任何帮助

我也有同样的问题

amazon提供的PHP参考和示例将答案深藏其中。整件事都是烤宽面条代码的典型例子,读起来就像是对各地编码人员的侮辱

API需要一个包含所有请求数据的HTTP POST和一个使用您的密钥进行的签名。数组的排序和url编码标准将字符串更改为符号

亚马逊希望它的分类如下:

uksort($params, 'strcmp');
$url_string = http_build_query($params,'','&',PHP_QUERY_RFC3986);
'Timestamp' => gmdate("Y-m-d\TH:i:s\\Z", time()),
忘了整个$url\u部分吧,它很混乱。使用http\u build\u query()代替,如下所示:

uksort($params, 'strcmp');
$url_string = http_build_query($params,'','&',PHP_QUERY_RFC3986);
'Timestamp' => gmdate("Y-m-d\TH:i:s\\Z", time()),
Amazon需要RFC3986,因此空格编码为“+”,而不是“%20”。此外,时间戳应如下所示:

uksort($params, 'strcmp');
$url_string = http_build_query($params,'','&',PHP_QUERY_RFC3986);
'Timestamp' => gmdate("Y-m-d\TH:i:s\\Z", time()),

祝你好运。

当你的机器/服务器的时间不正确时,就会发生这种情况。当我重新启动服务器时,有时会发生这种情况。只需设置与时间服务器的同步

我收到此错误:
请求签名太远。
这是因为我的计算机的时钟不正确。您必须更改方法才能获取。