使用eBay API时,在多个页面中显示结果

时间:2018-05-22 09:19:32

标签: php api ebay

即使我使用paginationInput.pageNumber=3";后,结果集也只显示一页。

如何在多个页面中显示结果并在底部显示页面链接?

    $apicall .= "&paginationInput.entriesPerPage=12";
    $apicall .= "&paginationInput.pageNumber=3";"

以上字段在eBay开发人员办公桌中指定,他们也在使用xml,但我没有得到以下代码的结果:

<?php
    $endpoint  = 'http://svcs.ebay.com/services/search/FindingService/v1'; // URL to call
    $version   = '1.11.0'; // API version supported by your application
    $appid     = 'myid'; // Replace with your own AppID
    $globalid  = 'EBAY-AU'; // Global ID of the eBay site you want to search (e.g., EBAY-DE)
    $query     = 'smartphones'; // You may want to supply your own query
    $safequery = urlencode($query); // Make the query URL-friendly

    // Construct the findItemsByKeywords HTTP GET call
    $apicall = "$endpoint?";
    $apicall .= "OPERATION-NAME=findItemsAdvanced";
    $apicall .= "&SERVICE-VERSION=$version";
    $apicall .= "&SECURITY-APPNAME=$appid";
    $apicall .= "&GLOBAL-ID=$globalid";
    $apicall .= "&keywords=$safequery";
    $apicall .= "&paginationInput.entriesPerPage=12";
    $apicall .= "&paginationInput.pageNumber=3";


    $knt=0;

    // 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;
            $price = $item->sellingStatus->currentPrice;

            // For each SearchResultItem node, build a link and append it to $results
            $results .= "<div id='prod-wrap'><div class='prodimg-wrap' align='center'><img src=\"$pic\" class='prodimg'></div> <div class='prodtxt' align='center'><a href=\"$link\">$title</a></div><div class='price' align='center'><p class='price' align='center'>$price</p></div></div>";
            $knt++;
        }
    }
    // 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>";
    }
    ?>
    <!-- Build the HTML page with values from the call response -->
    <html>
    <head>
        <style type="text/css">
            body {
                font-family: arial, sans-serif;
            }

            img {
                border: none;
            }

            #store-wrap {
                width:    770px;
                height:   auto;
                position: relative;
            }

            #filter-wrap {
                width:            160px;
                float:            left;
                height:           500px;
                margin-right:     10px;
                background-color: #EBEBEB;
            }

            #result-wrap {
                width:    600px;
                float:    left;
                height:   auto;
                position: relative;
            }

            #pagination-wrap {
                width:  200px;
                float:  right;
                height: 20px;
            }

            #prod-wrap {
                width:            150px;
                height:           200px;
                margin:           0 15px 15px;
                float:            left;
                border:           1px solid #999999;
                background-color: #CCCCCC;
            }

            .prodimg-wrap {
                width: 150px;
            }

            .prodimg {
                width:   100px;
                height:  100px;
                padding: 4px;
            }

            .prodtxt {
                font-size: 11px;
                width:     130px;
                padding:   0 8px;
            }
            .price {
                font-size: 11px;
                width: 60px;
                padding: 0 8px;
            }
            .price p {
                font-size: 11px;
                color: black;
            }
        </style>
    </head>
    <body>

    <h1><?php echo $query; ?></h1>

    <table>
        <tr>
            <td>
                <div id="store-wrap">

                    <div id="result-wrap">
                        <?php echo $results;?>

                    </div>
                </div>
            </td>
        </tr>
    </table>
     <?php echo $knt;?>


    </body>
    </html>

1 个答案:

答案 0 :(得分:0)

您只能从易趣的API一次检索1页数据/项目。指定第3页只会检索第3页,而不是第1-2页。如果您想要所有3个页面,那么您需要进行3次顺序API调用并在将数据显示在本地之前将其以HTML格式显示给最终用户。