Tomcat 类路径加载器 javax.mail.Session 与 spring-boot-starter-mail 冲突

Tomcat classpath loader javax.mail.Session conflict with spring-boot-starter-mail

正在尝试在 Tomcat(不是嵌入式 Tomcat)上部署 Spring 启动应用程序。我已经在 Tomcat 服务器配置上配置了一个 Java 邮件会话,我正试图在我的应用程序中将其作为 JNDI 值进行访问。出于某种原因,我的应用出现错误并显示:

Caused by: java.lang.IllegalArgumentException: The local resource link [support] that refers to global resource [mail/support] was expected to return an instance of [javax.mail.Session] but returned an instance of [javax.mail.Session]
        at org.apache.naming.factory.ResourceLinkFactory.getObjectInstance(ResourceLinkFactory.java:163)
        at javax.naming.spi.NamingManager.getObjectInstance(NamingManager.java:321)
        at org.apache.naming.NamingContext.lookup(NamingContext.java:840)

我已将 javax.mail.jar 包含在 Tomcat /lib 文件夹中。我的 pom.xml

中也包含 spring-boot-starter-mail

我尝试从 Tomcat 的库中删除 javax.mail.jar,但这会导致 Tomcat 启动时出错,因为它无法创建邮件会话。我也试过删除 spring-boot-starter-mail,但这会干扰我的一些需要 JavaMailSender 和其他邮件组件的代码。我试过弄乱 JNDI 导入和类似的东西,但无济于事。我还尝试检查 spring-boot-starter-mail 中包含的邮​​件 jar 版本,并更新 Tomcat 中的 jar 以匹配。我还检查了 Maven 中的传递依赖项,看看是否引入了不同的邮件实现,但什么也没有。所以我有点没主意了。

这是我在 web.xml 中获取 JNDI 值的地方:

<resource-ref>
        <description>The mail session configured in Tomcat</description>
        <res-ref-name>mail/support</res-ref-name>
        <res-type>javax.mail.Session</res-type>
        <res-auth>Container</res-auth>
    </resource-ref>

这是我在 Tomcat 的 server.xml 中配置的内容:

<GlobalNamingResources>
<Resource name="mail/support"
              auth="Container"
              type="javax.mail.Session"
              mail.smtp.host="smtp.XXX.XXX"
              mail.smtp.user="support"
              mail.smtp.from="support@XXX.org" />
</GlobalNamingResources>

下面是 context.xml 中的内容:

<Context>
<ResourceLink global="mail/support" name="mail/support" type="javax.mail.Session" />
</Context>

我希望能够使用 spring-boot-starter-mail,并使用全局配置的 JNDI 邮件会话。我不知道这些是否只是不相容的愿望,但我不明白为什么它们应该是。

好的,所以解决方案确实是@Bill Shannon 所建议的。我必须将 com.sun.mail 依赖项包含在 Maven provided 作用域中。我的特殊问题是该项目已经在使用 spring-boot-starter-mail 依赖项,其中包括 com.sun.mail jar。所以我不得不从我的 Maven 依赖中排除它。因此,与邮件内容相关的完整 Maven 依赖项如下所示:

<dependency>
    <groupId>com.sun.mail</groupId>
    <artifactId>javax.mail</artifactId>
    <version>1.5.6</version>
    <scope>provided</scope>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-mail</artifactId>
    <exclusions>
        <exclusion>
            <groupId>com.sun.mail</groupId>
            <artifactId>javax.mail</artifactId>
        </exclusion>
    </exclusions>
</dependency>

现在看起来有点明显了。我认为我的主要困惑来源是奇怪的 Tomcat 错误消息。感谢所有查看此内容的人,希望这可以解决其他人的问题!