易趣API - 如何获取大件物品图片?

Car*_*son 11 php ebay-api

如何使用eBay API获取大型商品图片?当我使用galleryURL时,下面的API调用返回缩略图图像.我尝试用PictureURLLarge替换它,但是没有返回URL.

(我指的是从底部开始的第16行:$ pic = $ item-> galleryURL;)

// API request variables
       $endpoint = 'http://svcs.ebay.com/services/search/FindingService/v1';  // URL to call
       $version = '1.11.0';  // API version supported by your application
       $appid = 'XXXXX';  // Replace with your own AppID
       $globalid = 'EBAY-US';  // Global ID of the eBay site you want to search (e.g., EBAY-DE)
       $query = "soft thin (shirt, tshirt, t-shirt)";  // Supply your own query
       $safequery = urlencode($query);  // Make the query URL-friendly
       $i = '0';  // Initialize the item filter index to 0

       // Create a PHP array of the item filters you want to use in your request
       $filterarray =
         array(
           array(
           'name' => 'MaxPrice',
           'value' => '1500',
           'paramName' => 'Currency',
           'paramValue' => 'USD'),
           array(
           'name' => 'FreeShippingOnly',
           'value' => 'false',
           'paramName' => '',
           'paramValue' => ''),
           array(
           'name' => 'ListingType',
           'value' => array('AuctionWithBIN','FixedPrice','StoreInventory'),
           'paramName' => '',
           'paramValue' => ''),
         );

       // Generates an indexed URL snippet from the array of item filters
       function buildURLArray ($filterarray) {
         global $urlfilter;
         global $i;
         // Iterate through each filter in the array
         foreach($filterarray as $itemfilter) {
           // Iterate through each key in the filter
           foreach ($itemfilter as $key =>$value) {
             if(is_array($value)) {
               foreach($value as $j => $content) { // Index the key for each value
                 $urlfilter .= "&itemFilter($i).$key($j)=$content";
               }
             }
             else {
               if($value != "") {
                 $urlfilter .= "&itemFilter($i).$key=$value";
               }
             }
           }
           $i++;
         }
         return "$urlfilter";
       } // End of buildURLArray function

       // Build the indexed item filter URL snippet
       buildURLArray($filterarray);

       // Construct the findItemsAdvanced HTTP GET call 
       $apicall = "$endpoint?";
       $apicall .= "OPERATION-NAME=findItemsAdvanced";
       $apicall .= "&SERVICE-VERSION=$version";
       $apicall .= "&SECURITY-APPNAME=$appid";
       $apicall .= "&GLOBAL-ID=$globalid";
       $apicall .= "&descriptionSearch=true";
       $apicall .= "&categoryId=110";
       $apicall .= "&keywords=$safequery";
       $apicall .= "&paginationInput.entriesPerPage=100";
       $apicall .= "$urlfilter";

       // Load the call and capture the document returned by eBay API
       $resp = simplexml_load_file($apicall);

       // Check to see if the request was successful, else print an error
       if ($resp->ack == "Success") {
         $results = '';
         // If the response was loaded, parse it and build links  
         foreach($resp->searchResult->item as $item) {
           $pic    = $item->galleryURL;
           $link   = $item->viewItemURL;
           $title  = $item->title;
           $ship = (float) $item->shippingInfo->shippingServiceCost;
           $price = (float) $item->sellingStatus->currentPrice;
           $sell = ($ship + $price);

           // For each SearchResultItem node, build a link and append it to $results
           $results .= "<a href=\"$link\" title=\"$title\" target=\"_blank\"><div class=\"shirt-block\"><img src=\"$pic\" width=\"200\" height=\"200\"><br /><br /><span class=\"cost\">$$sell</span></div></a>";
         }
       }
       // If the response does not indicate 'Success,' print an error
       else {
         $results  = "<h3>Oops! The request was not successful. Make sure you are using a valid ";
         $results .= "AppID for the Production environment.</h3>";
       }
Run Code Online (Sandbox Code Playgroud)

art*_*ics 7

您是否尝试过eBay 论坛提供的最新方法

我可以帮助解释和指导你.

该成员建议包含$apicall .= "&outputSelector=$outputSelector";在您的findItemsAdvanced请求构造中.

此时我会检查返回的XML文件,看看它是否包含在Firebug中(单击NET选项卡,然后单击下面的XHR).在Chrome中,只需启用开发人员工具,然后点击"网络"标签即可查看返回的XML文件.单击文件以展开,您将看到没有空格的内容.

因为XML文件不会很漂亮,所以复制该内容然后将其粘贴到此处以美化它以便于阅读.

示例XML文件HERE,显示了pictureURLLargepictureURLSuperSize.

验证大型图像的URL已包含在XML文件中后,第二步就是在标记中使用它,如下所示:

$pic = $item->pictureURLLarge;
Run Code Online (Sandbox Code Playgroud)

要么

$pic = $item->pictureURLSuperSize;
Run Code Online (Sandbox Code Playgroud)

抱歉,我没有自己的eBay AppID进行测试,他们的API Playground链接已被破坏,但可以进一步协助任何不清楚的地方.

可以肯定的是,第一步是获取大图像请求,第二步是简单地使用图像.