kotlin - Reactor-加载分页API的所有页面

标签 kotlin project-reactor reactor

我想知道Reactor和分页的HTTP API。我有一个private fun getPage(pageNumber: Int): Mono<SomePaginatedResouce>。该资源具有“numberOfPages”字段,我想获取所有页面。

第一次尝试如下:

getPage(1)
    .map { it.numberOfPages }
    .flatMapMany { Flux.range(1, it) }
    .flatMap { getPage(it) }

它可以正常工作并获取我的数据。但是,我想避免两次请求首页。所以我在想:
getPage(1)
    .expand { it ->
        if (it.isFirst) {
            // If it is the first page, load the rest of the pages
            Flux.range(2, it.numberOfPages)
                    .flatMap { getPage(it) }
        } else {
            // If it is a subsequent page, don't load anything
            Flux.empty()
        }
    }

有没有比使用expand并在我的资源中引入特殊标志更好的方法呢?

最佳答案

您可以执行以下操作:

getPage(1).flatMapMany(
        it -> Flux.concat(Mono.just(it), Flux.range(2, it.numberOfPages - 1).flatMap(this::getPage))
);

害怕它是Java而不是Kotlin,但翻译起来应该微不足道。

(请记住,Flux.range()适用于“开始”和“计数”参数,而不适用于“第一个索引”和“最后一个索引”。)

关于kotlin - Reactor-加载分页API的所有页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59355745/

相关文章:

android - 如何在没有第 3 方解析器的情况下在 Kotlin 中解析 JSON?

java - Flux.buffer() 不适用于 switchIfEmpty

spring-webflux - Spring Webflux - 服务器/客户端线程利用率

Kotlin 类委托(delegate)特性

android - titleList 显示不正确..?

spring-boot - Webclient 在 Docker 中泄漏内存?

java - Spring Reactor 合并与 Concat

python - 从 python 中定期运行 Scrapy 会导致 ReactorAlreadyRunning

带有 REST 服务的 Spring Reactor

android - 有没有办法动态更改 compose 的 Text() 中的字符串?