消息通道一个或多个



我需要处理大约30个地址的电子邮件。我以一种方式实现这一点,所有的电子邮件都要到一个DirectChannel,然后到Receiver。在Receiver中,我可以从地址中理解消息的来源,为此,我创建了CustomMessageSource,将javax.mail.Message包装为我自己的类型,其中包含javax.mail.Message和一些Enum。看起来这不是一个好的决定,因为我可以使用@Transformer,但如果我只有1个通道,我怎么能使用它?

这是第一个问题

第二个问题:

我应该使用一个通道和一个接收器来接收所有地址吗?还是每个邮件地址都有一个通道和接收者更好?我对春天的理解没有那么深,感觉不到它的不同。

注。这个问题是Spring多个imapAdapter的延续

在每个子上下文中,你可以添加一个header富集器来为来自适配器的URL设置一个自定义header;输出通道是到共享服务的共享通道。

在业务中,使用void foo(Message emailMessage, @Header("myHeader") String url)

我通常建议使用单个服务,除非该服务需要根据源代码做完全不同的事情。

编辑:

我修改了我对你之前问题的回答,以增强标题中的url的原始消息;每个实例都有自己的header富集器,它们都将富集后的消息路由到共同的emailChannel

@Configuration
@EnableIntegration
public class GeneralImapAdapter {
    @Value("${imap.url}")
    String imapUrl;
    @Bean
    public static PropertySourcesPlaceholderConfigurer pspc() {
        return new PropertySourcesPlaceholderConfigurer();
    }
    @Bean
    @InboundChannelAdapter(value = "enrichHeadersChannel", poller = @Poller(fixedDelay = "10000") )
    public MessageSource<javax.mail.Message> mailMessageSource(MailReceiver imapMailReceiver) {
        return new MailReceivingMessageSource(imapMailReceiver);
    }
    @Bean
    public MessageChannel enrichHeadersChannel() {
        return new DirectChannel();
    }
    @Bean
    @Transformer(inputChannel="enrichHeadersChannel", outputChannel="emailChannel")
    public HeaderEnricher enrichHeaders() {
        Map<String, ? extends HeaderValueMessageProcessor<?>> headersToAdd =
                Collections.singletonMap("emailUrl", new StaticHeaderValueMessageProcessor<>(this.imapUrl));
        HeaderEnricher enricher = new HeaderEnricher(headersToAdd);
        return enricher;
    }
    @Bean
    public MailReceiver imapMailReceiver() {
        MailReceiver receiver = mock(MailReceiver.class);
        Message message = mock(Message.class);
        when(message.toString()).thenReturn("Message from " + this.imapUrl);
        Message[] messages = new Message[] {message};
        try {
            when(receiver.receive()).thenReturn(messages);
        }
        catch (MessagingException e) {
            e.printStackTrace();
        }
        return receiver;
    }
}

…我修改了接收服务,所以它可以访问标题…

@MessageEndpoint
public class EmailReceiverService {
    @ServiceActivator(inputChannel="emailChannel")
    public void handleMessage(Message message, @Header("emailUrl") String url) {
        System.out.println(message + " header:" + url);
    }
}

…希望对你有帮助。

编辑2 :

这个更复杂一点;它从有效载荷中提取并将其放入标题中;您的用例不需要,因为您有完整的消息,但它说明了该技术…

@Bean
@Transformer(inputChannel="enrichHeadersChannel", outputChannel="emailChannel")
public HeaderEnricher enrichHeaders() {
    Map<String, HeaderValueMessageProcessor<?>> headersToAdd = new HashMap<>();
    headersToAdd.put("emailUrl", new StaticHeaderValueMessageProcessor<String>(this.imapUrl));
    Expression expression = new SpelExpressionParser().parseExpression("payload.from[0].toString()");
    headersToAdd.put("from", new ExpressionEvaluatingHeaderValueMessageProcessor<>(expression, String.class));
    HeaderEnricher enricher = new HeaderEnricher(headersToAdd);
    return enricher;
}

@ServiceActivator(inputChannel="emailChannel")
public void handleMessage(Message message, @Header("emailUrl") String url,
                                           @Header("from") String from) {
    System.out.println(message + " header:" + url + " from:" + from);
}

相关内容

最新更新