我正在为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)
答案 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();
}