2010-04-09 95 views
1

我在通过我的CodeIgniter中的PHP使用亚马逊web servise搜索时遇到问题。我得到的InvalidParameter时间戳不是来自服务器的ISO-8601格式响应。但我认为时间戳并不是问题,因为我试图与http://associates-amazon.s3.amazonaws.com/signed-requests/helper/index.html中给定的日期格式进行比较,这看起来很好。谁能帮忙?这是我的代码:Codeigniter或PHP亚马逊API帮助

   $private_key = 'XXXXXXXXXXXXXXXX'; // Took out real secret key 
       $method = "GET"; 
       $host = "ecs.amazonaws.com"; 
       $uri = "/onca/xml"; 

       $timeStamp = gmdate("Y-m-d\TH:i:s.000\Z"); 
       $timeStamp = str_replace(":", "%3A", $timeStamp); 
       $params["AWSAccesskeyId"] = "XXXXXXXXXXXX"; // Took out real access key 
       $params["ItemPage"] = $item_page; 
       $params["Keywords"] = $keywords; 
       $params["ResponseGroup"] = "Medium2%2525COffers"; 
       $params["SearchIndex"] = "Books"; 
       $params["Operation"] = "ItemSearch"; 
       $params["Service"] = "AWSECommerceService"; 
       $params["Timestamp"] = $timeStamp; 
       $params["Version"] = "2009-03-31"; 

       ksort($params); 

       $canonicalized_query = array(); 
       foreach ($params as $param=>$value) 
       { 
        $param = str_replace("%7E", "~", rawurlencode($param)); 
        $value = str_replace("%7E", "~", rawurlencode($value)); 
        $canonicalized_query[] = $param. "=". $value; 
       } 
       $canonicalized_query = implode("&", $canonicalized_query); 

       $string_to_sign = $method."\n\r".$host."\n\r".$uri."\n\r".$canonicalized_query; 

       $signature = base64_encode(hash_hmac("sha256",$string_to_sign, $private_key, True)); 

       $signature = str_replace("%7E", "~", rawurlencode($signature)); 

       $request = "http://".$host.$uri."?".$canonicalized_query."&Signature=".$signature; 

       $response = @file_get_contents($request); 

       if ($response === False) 
       { 
        return "response fail"; 
       } 
       else 
       { 
        $parsed_xml = simplexml_load_string($response); 
        if ($parsed_xml === False) 
        { 
         return "parse fail"; 
        } 
        else 
        { 
         return $parsed_xml; 
        } 
       } 

P.S. - 就我个人而言,我认为在对它进行哈希处理时,从$ string_to_sign中产生一些错误。

回答

3

你可以试试这个:

// some paramters 
$method = "GET"; 
$host = "ecs.amazonaws.".$region; 
$uri = "/onca/xml"; 

// additional parameters 
$params["Service"] = "AWSECommerceService"; 
$params["AWSAccessKeyId"] = $public_key; 
// GMT timestamp 
$params["Timestamp"] = gmdate("Y-m-d\TH:i:s\Z"); 
// API version 
$params["Version"] = "2009-03-31"; 

// sort the parameters 
ksort($params); 

// create the canonicalized query 
$canonicalized_query = array(); 
foreach ($params as $param=>$value) 
{ 
    $param = str_replace("%7E", "~", rawurlencode($param)); 
    $value = str_replace("%7E", "~", rawurlencode($value)); 
    $canonicalized_query[] = $param."=".$value; 
} 
$canonicalized_query = implode("&", $canonicalized_query); 

// create the string to sign 
$string_to_sign = $method."\n".$host."\n".$uri."\n".$canonicalized_query; 

// calculate HMAC with SHA256 and base64-encoding 
$signature = base64_encode(hash_hmac("sha256", $string_to_sign, $private_key, True)); 

// encode the signature for the request 
$signature = str_replace("%7E", "~", rawurlencode($signature)); 

// create request 
$request = "http://".$host.$uri."?".$canonicalized_query."&Signature=".$signature; 

// do request 
$response = @file_get_contents($request); 

if ($response === False) 
{ 
    return False; 
} 
else 
{ 
    // parse XML 
    $pxml = simplexml_load_string($response); 
    if ($pxml === False) 
    { 
     return False; // no xml 
    } 
    else 
    { 
     return $pxml; 
    } 
} 

// public and private keys 
$public_key = "xxxxxxxxxxxxxxxxxxxxxxxx"; 
$private_key = "xxxxxxxxxxxxxxxxxxxxxxxxxxx"; 

// the request 
$pxml = aws_signed_request("com", array("Operation"=>"ItemLookup", 
         "ItemId"=>"B000X9FLKM", 
         "ResponseGroup"=>"Small"), 
         $public_key, 
         $private_key);