NodeJs:获取分页的GET请求

7
当从stackexchange API请求Q&A时,JSON响应具有一个has_more(布尔)参数,当它为true时,这意味着还可以进行更多的请求。
http://api.stackexchange.com/2.2/questions?order=desc&sort=activity&site=stackoverflow&filter=withbody&pagesize=30&tagged=java&page=1

响应看起来像这样

{items: [
      ..]
 has_more: true,
 quota_max: 300,
 quota_remaining: 281
}

我希望找到一种最好的方法,在保持配额限制的情况下获取所有可能的响应。 目前,我的模块只能获取一个结果:

exports.getQuestions = function(q,tag,page){
return new Promise(function(resolve, reject){

var request = require('request');
var url = 'http://api.stackexchange.com/2.2/search?order=desc&sort=votes&site=stackoverflow&filter=withbody&pagesize=30';


url = url + '&q=' + q + '&tagged='+ tag + "&page="+page;

request({headers: {
    'Accept': 'application/json; charset=utf-8',
    'User-Agent': 'RandomHeader'
         },
     uri: url,
     method: 'GET',
     gzip: true
         },
function(err, res, body) {
if (err || res.statusCode !=200){
            reject (err || {statusCode: res.statusCode});
      }
     resolve(body);
          });
})}

但我希望以正确的方式循环遍历或进行多次调用。欢迎任何帮助。

1个回答

13

你可以使用async await结合你的getQuestions实现,只需循环请求页面直到has_more为false或达到配额限制...

async function getAllQuestions(q,tag){
    var page = 0 
    var res = await getQuestions(q,tag,page)
    var all = [res]
    while(res.has_more && res.quota_remaining > 0){
        page++
        res=await getQuestions(q,tag,page)
        all.push(res)
    }
    return all
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接