@Bean
public HttpMessageHandlerSpec documentumPolledInbound() {
return Http
.outboundGateway("/fintegration/getReadyForReimInvoices/Cz", restTemplate)
.expectedResponseType(String.class)
.errorHandler(new DefaultResponseErrorHandler())
;
}
如何轮询上面的内容,获取有效负载以便进一步处理
HTTP客户端端点不可轮询,但是事件驱动。因此,正如您通常从curl
调用一些REST服务,例如,这里也会发生相同的情况。我想,你有一些.handle()
,这个documentumPolledInbound()
并且有一些消息通道发送消息来触发这个端点来调用你的REST服务。
不清楚你将如何处理响应,但有一种方法可以定期触发事件来调用此端点。
为此,我们只能* mock *一个可以配置一些触发器策略的入站通道适配器:
@Bean
public IntegrationFlow httpPollingFlow() {
return IntegrationFlows
.from(() -> "", e -> e.poller(p -> p.fixedDelay(10, TimeUnit.SECONDS)))
.handle(documentumPolledInbound())
.get();
}
这样我们就会发送一个带有空字符串作为有效负载的消息到handle()
的通道。我们每隔10秒就这样做。
由于你的HttpMessageHandlerSpec
并不关心入站有效载荷,因此我们从轮询通道适配器中的MessageSource
返回的内容并不重要。