0

0

Java常用邮件发送类库与JavaMail API

P粉602998670

P粉602998670

发布时间:2026-01-06 18:03:08

|

412人浏览过

|

来源于php中文网

原创

JavaMail API 是 Oracle 提供的邮件协议抽象层,现已被 Jakarta Mail 取代;推荐使用 Spring 的 JavaMailSender 或 Simple Java Mail 等封装方案以避免底层配置错误。

java常用邮件发送类库与javamail api

JavaMail API 是什么,现在还该用吗

JavaMail API 是 Oracle 提供的官方邮件协议抽象层(javax.mail),底层封装了 SMTP/POP3/IMAP 协议交互逻辑。但它本身不实现网络通信,必须搭配具体 Provider(如 smtp.jar)才能工作。从 Java EE 7 开始,它已从 JDK 中移除;Java 11+ 完全不包含,需手动引入依赖。

如果你在用 Spring Boot,spring-boot-starter-mail 底层默认仍基于 JavaMail API(使用 jakarta.mail 迁移版),但屏蔽了大部分底层细节。纯 Java SE 项目若还要手写 SessionMimeMessageTransport.send(),容易出编码、认证、SSL/TLS 配置错误——这不是 API 设计问题,而是协议细节太琐碎。

  • Java 8–10:可用 javax.mail:javax.mail-api + com.sun.mail:javax.mail
  • Java 11+:必须用 Jakarta EE 版本:jakarta.mail:jakarta.mail-apiorg.eclipse.angus:angus-mail(原 GlassFish Mail 的继任者)
  • Spring Boot 3.x 已全面切换到 jakarta.mail,直接依赖 spring-boot-starter-mail 即可,无需再管类名迁移

为什么推荐 Spring Framework 的 JavaMailSender 而非裸用 JavaMail API

裸调 JavaMail API 写一封带附件的 HTML 邮件,要处理 MIME 类型、字符集、Base64 编码、边界分隔符、Content-ID 引用……稍有不慎就出现乱码、附件打不开、图片不显示。而 JavaMailSender 把这些封装成声明式操作,错误集中在配置阶段(比如 mail.smtp.auth=true 忘设),而非运行时难调试的字节流问题。

关键差异点:

立即学习Java免费学习笔记(深入)”;

AlegroCart
AlegroCart

AlegroCart新功能:维类:包括在这两种线性长宽高或面积或体积长波产品尺寸允许与期权产品:让产品/期权组合独特的数量,尺寸,图像和型号。选择店铺标识管理 图片放大镜:显示一个图片放大上空盘旋时,产品形象弹出框。自定义错误报告:设置在管理员启用。 开发者只可以显示详细的信息。错误信息都写入到错误日志文件每天可以通过电子邮件发送给管理员。仓库皮卡航运模块:允许客户指定产品在商店的位置回升。增加了

下载
  • JavaMailSender 是接口,Spring 默认实现是 JavaMailSenderImpl,它自动适配 jakarta.mail.Session,且支持连接池(通过 setSession() 复用)
  • 发送方法统一为 send(MimeMessagePreparator)send(SimpleMailMessage),避免手动 new MimeMessage 和 setFrom/setRecipients 等易错链式调用
  • 异常类型更明确:MailAuthenticationExceptionMailSendException 直接对应问题根源,不像裸 API 只抛 javax.mail.AuthenticationFailedException 或底层 IOException
SimpleMailMessage message = new SimpleMailMessage();
message.setFrom("no-reply@example.com");
message.setTo("user@test.com");
message.setSubject("订单确认");
message.setText("您的订单已提交,预计24小时内发货。");
javaMailSender.send(message);

常见失败场景与对应配置项

90% 的邮件发送失败不是代码问题,而是 SMTP 配置与服务商策略不匹配。以下是真实高频报错及解法:

  • javax.mail.AuthenticationFailedException:检查 mail.smtp.auth 是否为 true,且用户名密码是否为应用专用密码(如 Gmail 开启两步验证后需用 App Password,而非账户登录密码)
  • Could not convert socket to TLS:说明服务器要求 STARTTLS,但代码用了 mail.smtp.ssl.enable=true(这是 SSL/TLS 直连,端口通常是 465)。应改用 mail.smtp.starttls.enable=true + 端口 587
  • 中文主题/正文乱码:确保 mail.mime.charset=UTF-8,且 SimpleMailMessage 不支持 HTML,要用 MimeMessagePreparator 并显式设置 message.setContent(..., "text/html;charset=UTF-8")
  • 被 Gmail/Outlook 当垃圾邮件:发件人地址必须真实存在且经过 SPF/DKIM/DMARC 验证;避免纯 HTML、过多链接、敏感词;测试时先用公司域名邮箱,别用免费邮箱直连

轻量替代方案:Simple Java Mail

如果项目不用 Spring,又嫌 Jakarta Mail 配置太重,Simple Java Mail 是个务实选择。它本质是 JavaMail API 的 fluent 封装,不引入新协议,但把所有配置、MIME 构建、异常映射都收拢到一个入口。

优势在于零配置启动(内置主流邮箱默认值)、一行代码发 HTML+附件、支持异步发送、自带日志开关。它内部仍用 jakarta.mail,所以 Java 17+ 兼容性无压力。

Mailer mailer = MailerBuilder
    .withSMTPServer("smtp.gmail.com", 587, "you@gmail.com", "app-password")
    .buildMailer();

Email email = EmailBuilder.startingBlank()
    .from("Me", "me@example.com")
    .to("You", "you@example.com")
    .withSubject("Test")
    .withPlainText("Hi there!")
    .withHTMLText("

Hi there!

") .buildEmail(); mailer.sendMail(email);

注意:它的 Mailer 实例是线程安全的,可单例复用;但不要在高并发下频繁 new Email 对象而不复用 EmailBuilder,否则 GC 压力会上升。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

827

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

732

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

732

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

396

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16924

2023.08.03

PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.07

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.3万人学习

Java 教程
Java 教程

共578课时 | 43.2万人学习

oracle知识库
oracle知识库

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号