基于注解的配置
以下示例来自样本仓库,展示了在使用注解而非 XML 进行配置时的一些可用配置选项
@EnableIntegration (1)
@IntegrationComponentScan (2)
@Configuration
public static class Config {
@Value(${some.port})
private int port;
@MessagingGateway(defaultRequestChannel="toTcp") (3)
public interface Gateway {
String viaTcp(String in);
}
@Bean
@ServiceActivator(inputChannel="toTcp") (4)
public MessageHandler tcpOutGate(AbstractClientConnectionFactory connectionFactory) {
TcpOutboundGateway gate = new TcpOutboundGateway();
gate.setConnectionFactory(connectionFactory);
gate.setOutputChannelName("resultToString");
return gate;
}
@Bean (5)
public TcpInboundGateway tcpInGate(AbstractServerConnectionFactory connectionFactory) {
TcpInboundGateway inGate = new TcpInboundGateway();
inGate.setConnectionFactory(connectionFactory);
inGate.setRequestChannel(fromTcp());
return inGate;
}
@Bean
public MessageChannel fromTcp() {
return new DirectChannel();
}
@MessageEndpoint
public static class Echo { (6)
@Transformer(inputChannel="fromTcp", outputChannel="toEcho")
public String convert(byte[] bytes) {
return new String(bytes);
}
@ServiceActivator(inputChannel="toEcho")
public String upCase(String in) {
return in.toUpperCase();
}
@Transformer(inputChannel="resultToString")
public String convertResult(byte[] bytes) {
return new String(bytes);
}
}
@Bean
public AbstractClientConnectionFactory clientCF() { (7)
return new TcpNetClientConnectionFactory("localhost", this.port);
}
@Bean
public AbstractServerConnectionFactory serverCF() { (8)
return new TcpNetServerConnectionFactory(this.port);
}
}
1 | 标准的 Spring Integration 注解,用于启用集成应用的基础设施。 |
2 | 搜索 @MessagingGateway 接口。 |
3 | 流程客户端的入口点。调用应用程序可以使用 @Autowired 获取此 Gateway bean 并调用其方法。 |
4 | 出站端点由一个 MessageHandler 和一个包装它的消费者组成。在此场景中,@ServiceActivator 根据通道类型配置端点。 |
5 | 入站端点(在 TCP/UDP 模块中)都是消息驱动的,因此只需声明为简单的 @Bean 实例。 |
6 | 此类提供了许多 POJO 方法供此示例流程使用(服务器端有一个 @Transformer 和 @ServiceActivator,客户端有一个 @Transformer)。 |
7 | 客户端连接工厂。 |
8 | 服务器端连接工厂。 |