WSO2 ESB MailTransportListener没有收到

时间:2016-08-03 05:56:39

标签: wso2 wso2esb mailto

我刚安装了全新的WSO2 ESB 4.9.0。这是我昨天下载的最新版本。

我正在尝试让我的ESB从服务器接收电子邮件。我尝试过POP3和IMAP。我一直在使用几个参考资料来帮助我(因为我是新成员,我的声誉还不允许我发布所有参考文献的正确链接):

  • stackoverflow.com/questions/27376833/wso2-mailto-transport-emptied-my-inbox
  • javamail.java.net/nonav/docs/api/com/sun/mail/pop3/package-summary.html
  • javamail.java.net/nonav/docs/api/com/sun/mail/imap/package-summary.html
  • sparkletechthoughts.blogspot.fr/2013/10/how-to-receive-emails-to-wso2-esb.html
  • charithaka.blogspot.com/2012/11/how-to-enable-mail-transport-for-wso2.html
  • irhamiqbal.wordpress.com/how-to-receive-email-using-wso2-esb /
  • jayalalk.blogspot.com/2014/06/wso2-esb-mail-sending-with-html-complex.html

当然还有官方文件:

我的所有阅读都让我相信我已经正确设置了所有内容(或者如果不正确,足以获得一些错误消息进行故障排除)。

我确实重启了WSO2 ESB,并在控制台日志中显示以下消息:

TID[-1234] [ESB] [2016-08-02 21:45:37,237] INFO {org.apache.axis2.transport.mail.MailTransportListener} - MAILTO listener started 

我不会在日志中以这种或那种方式获得其他任何指示。

我编辑(并仔细检查)我的$ CARBON_HOME / repository / conf / axis2 / axis2.xml,我非常确定我已正确启用邮件传输:

<transportReceiver name="mailto" class="org.apache.axis2.transport.mail.MailTransportListener">
    <!-- configure any optional POP3/IMAP properties
    check com.sun.mail.pop3 and com.sun.mail.imap package documentation for more details-->
</transportReceiver>
<transportSender name="mailto" class="org.apache.axis2.transport.mail.MailTransportSender">
    <parameter name="mail.smtp.host">my.smtp.server</parameter>
    <parameter name="mail.smtp.port">587</parameter>
    <parameter name="mail.smtp.starttls.enable">false</parameter>
    <parameter name="mail.smtp.auth">true</parameter>
    <parameter name="mail.smtp.user">my@user.id</parameter>
    <parameter name="mail.smtp.password">password</parameter>
    <parameter name="mail.smtp.from">my@email.com</parameter>
</transportSender>

最后,我有我的代理服务设置(无论如何都在当前的迭代中):

<?xml version="1.0" encoding="UTF-8"?>
<proxy xmlns="http://ws.apache.org/ns/synapse"
       name="JasperEmailPOP3"
       transports="mailto"
       statistics="disable"
       trace="disable"
       startOnLoad="true">
   <target>
      <inSequence>
         <property name="senderAddress"
                   expression="get-property('transport', 'From')"
                   scope="default"
                   type="STRING"/>
         <log level="custom">
            <property name="Date" expression="$trp:Date"/>
            <property name="Subject" expression="$trp:Subject"/>
            <property name="Content-Type" expression="$trp:Content-Type"/>
            <property name="From" expression="$trp:From"/>
         </log>
         <drop/>
      </inSequence>
      <outSequence>
         <send/>
      </outSequence>
   </target>
   <parameter name="mail.pop3.socketFactory.class">javax.net.ssl.SSLSocketFactory</parameter>
   <parameter name="transport.PollInterval">5</parameter>
   <parameter name="mail.pop3.host">my.pop3.email</parameter>
   <parameter name="mail.pop3.user">my@email.com</parameter>
   <parameter name="transport.mail.Protocol">pop3</parameter>
   <parameter name="mail.pop3.socketFactory.port">995</parameter>
   <parameter name="transport.mail.Address">jasper@eryjus.com</parameter>
   <parameter name="mail.pop3.password">password</parameter>
   <parameter name="mail.pop3.port">995</parameter>
   <parameter name="mail.pop3.socketFactory.fallback">false</parameter>
   <description/>
</proxy>

有了这一切,我的问题是:是否还有一些我缺少的东西让ESB至少尝试检索电子邮件?困扰我的是我没有收到任何错误消息进行故障排除(例如我的邮件没有进行普通测试)。

1 个答案:

答案 0 :(得分:1)

我使用Gmail帐户尝试了相同的方案,它对我来说运行正常,看起来像是POP服务器中的一些错误配置。您还需要添加以下属性。

<parameter name="transport.mail.ContentType">text/plain</parameter>

请参阅下面的完整代理配置。

<?xml version="1.0" encoding="UTF-8"?>
<proxy xmlns="http://ws.apache.org/ns/synapse"
       name="JasperEmailPOP3"
       transports="mailto"
       statistics="disable"
       trace="disable"
       startOnLoad="true">
   <target>
      <inSequence>
         <property name="senderAddress"
                   expression="get-property('transport', 'From')"
                   scope="default"
                   type="STRING"/>
         <log level="custom">
            <property name="Date" expression="$trp:Date"/>
            <property name="Subject" expression="$trp:Subject"/>
            <property name="Content-Type" expression="$trp:Content-Type"/>
            <property name="From" expression="$trp:From"/>
         </log>
         <drop/>
      </inSequence>
      <outSequence>
         <send/>
      </outSequence>
   </target>
   <parameter name="mail.pop3.socketFactory.class">javax.net.ssl.SSLSocketFactory</parameter>
   <parameter name="transport.PollInterval">5</parameter>
   <parameter name="mail.pop3.host">pop.gmail.com</parameter>
   <parameter name="mail.pop3.user">ycwso2test</parameter>
   <parameter name="transport.mail.Protocol">pop3</parameter>
   <parameter name="mail.pop3.socketFactory.port">995</parameter>
   <parameter name="transport.mail.Address">ycwso2test@gmail.com</parameter>
   <parameter name="mail.pop3.password">wso2qa123</parameter>
   <parameter name="mail.pop3.port">995</parameter>
   <parameter name="mail.pop3.socketFactory.fallback">false</parameter>
   <parameter name="transport.mail.ContentType">text/plain</parameter>
   <description/>
</proxy>

此外,如果您需要进一步调试,可以启用DEBUG日志。为此,请将以下行添加到repository / conf / log4j.properties并重新启动。

log4j.logger.org.apache.axis2.transport.mail.MailTransportListener=DEBUG