DSL 和端点配置

所有IntegrationFlowBuilder EIP 方法都有一个变体,该变体应用 lambda 参数来为AbstractEndpoint 实例提供选项:SmartLifecyclePollerMetadatarequest-handler-advice-chain 等。它们每个都有泛型参数,因此允许您在上下文中配置端点甚至其MessageHandler,如下例所示

@Bean
public IntegrationFlow flow2() {
    return IntegrationFlow.from(this.inputChannel)
                .transformWith(t -> t
                              .transformer(new PayloadSerializingTransformer())
                              .autoStartup(false)
                              .id("payloadSerializingTransformer"))
                .transformWith(t -> t
                              .transformer((Integer p) -> p * 2)
                              .advice(expressionAdvice()))
                .get();
}

此外,EndpointSpec 提供了一个id() 方法,允许您使用给定的 bean 名称注册端点 bean,而不是生成的 bean 名称。

如果MessageHandler 被引用为 bean,那么如果 DSL 定义中存在.advice() 方法,则任何现有的adviceChain 配置都将被覆盖

@Bean
public TcpOutboundGateway tcpOut() {
    TcpOutboundGateway gateway = new TcpOutboundGateway();
    gateway.setConnectionFactory(cf());
    gateway.setAdviceChain(Collections.singletonList(fooAdvice()));
    return gateway;
}

@Bean
public IntegrationFlow clientTcpFlow() {
    return f -> f
        .handle(tcpOut(), e -> e.advice(testAdvice()))
        .transform(Transformers.objectToString());
}

它们不会合并,在这种情况下只使用testAdvice() bean。