Spring集成DSL在java 1.7中创建Mail出站通道适配器

时间:2015-08-20 14:32:32

标签: spring-integration

我正在为dsl中的邮件输出绑定通道创建一个特定的流程 我的流程是这样的,我通过Message GateWay从休息服务发送邮件然后消息将通过请求通道 对我自己定制的变换器,在传输消息之后将通过输出通道转到出站适配器。 因为我的变换器是一个单独的类,所以无法在我的整个流程中在dsl中编写集成流程。可以提供任何ony一个 任何指向它的指针,因为我无法继续。

这是我的DSL类包含邮件网关和mailSender bean .....

@MessagingGateway
interface MailGateWay{
@Gateway(requestChannel = "fromChannel")
public void sendMail(MessageDto msgDto) ;
}

@Bean
public QueueChannel fromChannel(){
    return new QueueChannel();
}

@Bean
public JavaMailSenderImpl mailSender() {
    JavaMailSenderImpl mail = new JavaMailSenderImpl();
    Properties javaMailProperties = new Properties();
    mail.setHost(host);
    mail.setPort(port);
    mail.setUsername(username);
    mail.setPassword(password);
    mail.setDefaultEncoding("UTF-8");
    javaMailProperties.setProperty("mail.transport.protocol", "smtp");
    javaMailProperties.setProperty("mail.smtp.auth", String.valueOf(true));
    javaMailProperties.setProperty("mail.smtp.starttls.enable", String.valueOf(false));
    javaMailProperties.setProperty("mail.debug", String.valueOf(true));
    mail.setJavaMailProperties(javaMailProperties);
    return mail;
}

Now my Transfrmer looks loke this, I have created a transformer bean in my dsl

@Bean
@Scope("prototype")
public MailMessageTransformer mailTransformer(){
    return new MailMessageTransformer();
}

@Bean
public QueueChannel outboundMailChannel(){
    return new QueueChannel();
}

这是我自定义的MailMessageTransformer类,我需要调用这个返回MimeMessage的transform()。

public class MailMessageTransformer {

@Autowired
private JavaMailSender mailSender;

public MimeMessage transform(final MessageDto mailDto) {        

    if (mailDto == null) {
        return null;
    }

    if (mailDto.getEncoding() == null) {
        mailDto.setEncoding(IMailConstants.DEFAULT_ENCODING);
    }       

    mailDto.setText(mailDto.getText().replaceAll(System.lineSeparator(), IMailConstants.HTML_NEW_LINE));

    MimeMessage mimeMessage = null;
    try {
        mimeMessage = mailSender.createMimeMessage();
        MimeMessageHelper message = new MimeMessageHelper(mimeMessage);
        message.setTo(mailDto.getTo());
        message.setFrom(mailDto.getFrom());
        message.setSubject(mailDto.getSubject());
        message.setText(getMailContent(mailDto), IMailConstants.TRUE);
        message.setSentDate(new Date(System.currentTimeMillis()));


        if (null != mailDto.getBcc()) {
            message.setBcc(mailDto.getBcc());
        }
        if (null != mailDto.getBcc()) {
            message.setCc(mailDto.getCc());
        }
        if (null != mailDto.getReplyTo() && !mailDto.getReplyTo().isEmpty()) {
            message.setReplyTo(mailDto.getReplyTo());
        }

    }
    catch (MessagingException msgex) {
        LOG.error("MailMessageTransformer.transformMime.Exception::: MessagingException", msgex);

    }
     catch (MailException mailex) {
            LOG.error("MailMessageTransformer.transformMime.Exception::: MailException ", mailex);

        }

    catch (Exception ex) {
        LOG.error("MailMessageTransformer.transformMime.Exception::: Exception", ex);

    }

    LOG.debug("MailMessageTransformer.transformMime.mimeMessage:::" + mimeMessage);
    return mimeMessage;
}
}

现在我需要创建一个dsl流,通过它我可以调用我的mailTransformer()bean并添加一个像下面的xml一样的轮询器。

<int:transformer input-channel="fromChannel"
output-channel="outboundMailChannel" ref="mailTransformer" method="transform">
<int:poller fixed-rate="6000" max-messages-per-poll="10" />

<int-mail:outbound-channel-adapter
    channel="outboundMailChannel" mail-sender="mailSender" />

流程是Gateway - &gt; RequsetChannel ---&gt;转换---&gt; OutboundMailChannl ---&gt; mailSender(MailAdapter)

1 个答案:

答案 0 :(得分:1)

抱歉,您的问题并不完全清楚。甚至更多你没有显示流量定义。再加上您的定制变压器。

从另一方面,您始终可以将.transform()用于指定为Transformer的任何自定义@Bean实施,或者甚至使用private方法来返回其实例。 DSL将关注ctx中的bean数量。

请注意DSL提供了邮件通信所需的一切。

还有一点。不要忘记您甚至可以使用@Gateway标记@RequestMapping方法,以绕过controller级别。

对不起,我真的不确定如何帮助你...

<强>更新

查看您的代码我真的没有看到任何问题,除非我没有看到@Scope("prototype")用于MailMessageTransformer @Bean的原因。

您的XML集成流程非常简单。我不清楚你在哪里拥挤:

@Bean
public IntegrationFlow emailFlow() {
    return IntegrationFlows
            .from(fromChannel())
            .transform(mailTransformer(),
                new Consumer<GenericEndpointSpec<MessageTransformingHandler>>() {

                    @Override
                    public void accept(GenericEndpointSpec<MessageTransformingHandler> spec) {
                        spec.poller(Pollers.fixedRate(6000).maxMessagesPerPoll(10));
                    }

            })
            .handle(new MailSendingMessageHandler(this.mailSender))
            .get();
    }