2013-08-04 108 views
0

我试图让WooCommerce来从亚马逊API的价格,但我很失败。我在PHP中很糟糕,但这是迄今为止我所拥有的。我无法让它工作。亚马逊API和Woocommerce桥梁

我正在使用我在线发现的模板来从Amazon API调用。这些都是文件:

<?php 

/** 
* Class to access Amazons Product Advertising API 
* @author Sameer Borate 
* @link http://www.codediesel.com 
* @version 1.0 
* All requests are not implemented here. You can easily 
* implement the others from the ones given below. 
*/ 


/* 
Permission is hereby granted, free of charge, to any person obtaining a 
copy of this software and associated documentation files (the "Software"), 
to deal in the Software without restriction, including without limitation 
the rights to use, copy, modify, merge, publish, distribute, sublicense, 
and/or sell copies of the Software, and to permit persons to whom the 
Software is furnished to do so, subject to the following conditions: 

The above copyright notice and this permission notice shall be included in 
all copies or substantial portions of the Software. 

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 
THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 
DEALINGS IN THE SOFTWARE. 
*/ 

require_once 'amazon_product_api_signed_request.php'; 

class AmazonProductAPI 
{ 
    /** 
    * Your Amazon Access Key Id 
    * @access private 
    * @var string 
    */ 
    private $public_key; 

    /** 
    * Your Amazon Secret Access Key 
    * @access private 
    * @var string 
    */ 
    private $private_key; 

    /** 
    * Your Amazon Associate Tag 
    * Now required, effective from 25th Oct. 2011 
    * @access private 
    * @var string 
    */ 
    private $associate_tag; 

    private $local_site; 

    /** 
    * Constants for product types 
    * @access public 
    * @var string 
    */ 

    /* 
     Only three categories are listed here. 
     More categories can be found here: 
     http://docs.amazonwebservices.com/AWSECommerceService/latest/DG/APPNDX_SearchIndexValues.html 
    */ 

    const MUSIC = "Music"; 
    const DVD = "DVD"; 
    const GAMES = "VideoGames"; 


    public function __construct($public, $private, $local_site, $associate_tag){ 

     $this->public_key = $public; 
     $this->private_key = $private; 
     $this->local_site = $local_site; 
     $this->associate_tag = $associate_tag; 

    } 

    public function get_local(){ 
     return $this->local_site; 
    } 

    /** 
    * Check if the xml received from Amazon is valid 
    * 
    * @param mixed $response xml response to check 
    * @return bool false if the xml is invalid 
    * @return mixed the xml response if it is valid 
    * @return exception if we could not connect to Amazon 
    */ 
    private function verifyXmlResponse($response) 
    { 
     if ($response === False) 
     { 
      throw new Exception("Could not connect to Amazon"); 
     } 
     else 
     { 
      if (isset($response->Items->Item->ItemAttributes->Title)) 
      { 
       return ($response); 
      } 
      else 
      { 
       throw new Exception("Invalid xml response."); 
      } 
     } 
    } 


    /** 
    * Query Amazon with the issued parameters 
    * 
    * @param array $parameters parameters to query around 
    * @return simpleXmlObject xml query response 
    */ 
    public function queryAmazon($parameters) 
    { 
     return amazon_product_api_signed_request($this->local_site, $parameters, $this->public_key, $this->private_key, $this->associate_tag); 
    } 


    /** 
    * Return details of products searched by various types 
    * 
    * @param string $search search term 
    * @param string $category search category   
    * @param string $searchType type of search 
    * @return mixed simpleXML object 
    */ 
    public function searchProducts($search, $category, $searchType = "UPC") 
    { 
     $allowedTypes = array("UPC", "TITLE", "ARTIST", "KEYWORD"); 
     $allowedCategories = array("Music", "DVD", "VideoGames"); 

     switch($searchType) 
     { 
      case "UPC" : $parameters = array("Operation"  => "ItemLookup", 
               "ItemId"  => $search, 
               "SearchIndex" => $category, 
               "IdType"  => "UPC", 
               "ResponseGroup" => "Medium"); 
          break; 

      case "TITLE" : $parameters = array("Operation"  => "ItemSearch", 
               "Title"   => $search, 
               "SearchIndex" => $category, 
               "ResponseGroup" => "Medium"); 
          break; 

     } 

     $xml_response = $this->queryAmazon($parameters); 

     return $this->verifyXmlResponse($xml_response); 

    } 




    public function getBrowseNodeProducts($category, $browseNode = 1000, $searchType = "UPC") 
    { 
     $allowedTypes = array("UPC", "TITLE", "ARTIST", "KEYWORD"); 
     $allowedCategories = array("Music", "DVD", "VideoGames"); 

     $parameters = array(
          "Operation"  => "ItemSearch", 
          "BrowseNode" => $browseNode, 
          "SearchIndex" => $category, 
          "ResponseGroup" => "Medium,Reviews" 
          ); 

     $xml_response = $this->queryAmazon($parameters); 

     return $this->verifyXmlResponse($xml_response); 

    } 


    /** 
    * Return details of a product searched by UPC 
    * 
    * @param int $upc_code UPC code of the product to search 
    * @param string $product_type type of the product 
    * @return mixed simpleXML object 
    */ 
    public function getItemByUpc($upc_code, $product_type) 
    { 
     $parameters = array("Operation"  => "ItemLookup", 
          "ItemId"  => $upc_code, 
          "SearchIndex" => $product_type, 
          "IdType"  => "UPC", 
          "ResponseGroup" => "Medium"); 

     $xml_response = $this->queryAmazon($parameters); 

     return $this->verifyXmlResponse($xml_response); 

    } 


    /** 
    * Return details of a product searched by ASIN 
    * 
    * @param int $asin_code ASIN code of the product to search 
    * @return mixed simpleXML object 
    */ 
    public function getItemByAsin($asin_code) 
    { 
     $parameters = array("Operation"  => "ItemLookup", 
          "ItemId"  => $asin_code, 
          "ResponseGroup" => "Medium"); 

     $xml_response = $this->queryAmazon($parameters); 

     return $this->verifyXmlResponse($xml_response); 
    } 


    /** 
    * Return details of a product searched by keyword 
    * 
    * @param string $keyword keyword to search 
    * @param string $product_type type of the product 
    * @return mixed simpleXML object 
    */ 
    public function getItemByKeyword($keyword, $product_type) 
    { 
     $parameters = array("Operation" => "ItemSearch", 
          "Keywords" => $keyword, 
          "SearchIndex" => $product_type); 

     $xml_response = $this->queryAmazon($parameters); 

     return $this->verifyXmlResponse($xml_response); 
    } 

} 

?> 

下面就来访问我相信API文件:

<?php 

function  amazon_product_api_signed_request($region,$params,$public_key,$private_key,$associate_tag) 
{ 

if($region == 'jp'){ 
    $host = "ecs.amazonaws.".$region; 
}else{ 
    $host = "webservices.amazon.".$region; 
} 

$method = "GET"; 
$uri = "/onca/xml"; 


$params["Service"]   = "AWSECommerceService"; 
$params["AWSAccessKeyId"] = $public_key; 
$params["AssociateTag"]  = $associate_tag; 
$params["Timestamp"]  = gmdate("Y-m-d\TH:i:s\Z"); 
$params["Version"]   = "2011-08-01"; 

/* The params need to be sorted by the key, as Amazon does this at 
    their end and then generates the hash of the same. If the params 
    are not in order then the generated hash will be different thus 
    failing the authetication process. 
*/ 
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".$host."\n".$uri."\n".$canonicalized_query; 

/* calculate the signature using HMAC with SHA256 and base64-encoding. 
    The 'hash_hmac' function is only available from PHP 5 >= 5.1.2. 
*/ 
$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; 

/* I prefer using CURL */ 
$ch = curl_init(); 
curl_setopt($ch, CURLOPT_URL,$request); 
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
curl_setopt($ch, CURLOPT_TIMEOUT, 15); 
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); 

$xml_response = curl_exec($ch); 

/* If cURL doesn't work for you, then use the 'file_get_contents' 
    function as given below. 
*/ 

if ($xml_response === False) 
{ 
    return False; 
} 
else 
{ 
    /* parse XML */ 
    $parsed_xml = @simplexml_load_string($xml_response); 
    return ($parsed_xml === False) ? False : $parsed_xml; 
} 
} 
?> 

这是我相信不会的价格WooCommerce功能:

function woocommerce_get_formatted_product_name($product) { 
if (! $product || ! is_object($product)) 
    return; 

if ($product->get_sku()) 
    $identifier = $product->get_sku(); 
elseif ($product->is_type('variation')) 
    $identifier = '#' . $product->variation_id; 
else 
    $identifier = '#' . $product->id; 

if ($product->is_type('variation')) { 
    $attributes = $product->get_variation_attributes(); 
    $extra_data = ' &ndash; ' . implode(', ', $attributes) . ' &ndash; ' . woocommerce_price($product->get_price()); 
} else { 
    $extra_data = ''; 
} 

return sprintf(__('%s &ndash; %s%s', 'woocommerce'), $identifier, $product- >get_title(), $extra_data); 
} 

这是我已经添加到functions.php文件中,希望能够让所有人都在一起,可悲的是,它不工作:(

​​

回答