因此,我对使用API相当陌生,我只是尝试使用Etsy API来显示特定的列表集。
默认情况下,API返回一组25个结果,并且一次最多可以返回100个结果。我想展示更多,所以我试图在我的呼叫中添加分页。到目前为止,我得到的是:
<?php
//setting API key
define("API_KEY", XXX);
//setting request url
$url = "https://openapi.etsy.com/v2/listings/active?keywords=unicorn,unicorns&includes=Images:1:0&api_key=" . API_KEY;
while (isset($url) && $url != '') {
$curl = curl_init($url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$response_body=curl_exec($curl);
curl_close($curl);
$response = json_decode($response_body);
foreach ($response->results as $listing) {
echo "<li>" . $listing->title . " ~*~ " . $listing->price . " " . $listing->currency_code . " ~*~ " . '<a href="' . $listing->url . '" target="_blank">View on Etsy!</a>' . "</li>" . "<br>";
}
$url = $response->pagination->next_page;
}
?>
我以为这会循环并返回下一组25个结果,但没有。有人有这方面的经验吗?有什么地方我被绊倒了吗?
谢谢!
在while
块中,将next_page
属性的值分配给$url
但实际值是int
,2,而不是url
相反,将next_page
附加到初始url,作为查询字符串变量。
$url .= "&page=" . $response->pagination->next_page;
请参阅下面的示例,了解如何将每个流程隔离为一个函数。
我们将curl
操作移到它自己的函数中,它从json_decode
返回一个对象。
我们将列表的整个处理转移到一个单独的功能中,目前,它只打印列表。
第二个函数是递归的,也就是说,如果下一个页面存在,它将调用第一个函数,获取响应,然后处理它
<?php
//setting API key
define("API_KEY", 'br4j52uzdtlcpp6qxb6we3ge');
function get_listings($page=1){
$url = "https://openapi.etsy.com/v2/listings/active?keywords=unicorn,unicorns&includes=Images:1:0&api_key=" . API_KEY;
$url .= "&page=$page";
$curl = curl_init($url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$response_body=curl_exec($curl);
curl_close($curl);
$responseObject = json_decode($response_body);
return $responseObject;
}
function process_listings($responseObject){
foreach ($responseObject->results as $listing) {
echo "Title: " . $listing->title . PHP_EOL .
"Price " . $listing->price . PHP_EOL .
"Currency code " . $listing->currency_code . PHP_EOL .
'URL ' . $listing->url . PHP_EOL;
}
print PHP_EOL . "Pagination " . $responseObject->pagination->next_page . PHP_EOL;
$next_page = $responseObject->pagination->next_page;
if ($next_page) {
$nextPageResponse = get_listings($next_page);
process_listings($nextPageResponse);
}
}
$firstPage = get_listings(); // page 1 is default
process_listings($firstPage);