nested exception is javax.mail.MessagingException: Exception reading response

场景

使用springboot mail发邮件,利用到公司的邮件服务器。先在本地写好代码在本地单元测试时报错

org.springframework.mail.MailSendException: Mail server connection failed; nested exception is javax.mail.MessagingException: Exception reading response;
nested exception is:
java.net.SocketException: Connection reset. Failed messages: javax.mail.MessagingException: Exception reading response;
nested exception is:
java.net.SocketException: Connection reset
; message exception details (1) are:
Failed message 1:
javax.mail.MessagingException: Exception reading response;
nested exception is:
java.net.SocketException: Connection reset

大意是连接被重置
查询资料一开始说需要配置超时时间在yaml里,配置完成后仍然失败

spring:
 mail:
  host: XX.com
  port: 25
  username: XXP@XX-auto.com
  properties:
   mail:
    debug: true
    smtp:
      #设置邮件发送超时时间
     timeout: 25000

解决

又查询了资料,发现 connect reset 问题有人是这样说。

网络策略阻止了对SMTP服务器的请求。我与网络管理员联系,他给了我所需的权限。现在一切正常。

对啊,我现在用的是公司的邮件服务器发邮件,肯定做了限制公司,我在本地机器上怎么可能发送成功呢,哪怕我连上了公司的vpn?
然后我将程序打个jar包放到公司集群某台机器中,果然发送成功,outlook收到了邮件
在这里插入图片描述后续和同事确认了之前的连接问题就是公司服务器配置问题

### 解析javax.mail.AuthenticationFailedException异常 当遇到`javax.mail.AuthenticationFailedException`异常时,通常意味着客户端无法通过身份验证来访问邮件服务器。此问题可能由多种因素引起,包括但不限于用户名或密码不正确、未启用必要的安全协议以及使用了错误类型的认证凭证。 对于特定于451错误的情况,该状态码表示服务器遇到了临时性的内部错误而无法处理请求。然而,在上下文中提到的具体问题是关于身份验证失败(535),这表明虽然服务器本身运行正常,但由于提供的凭据无效而导致操作被拒绝[^2]。 #### 配置检查与修正 为了成功发送电子邮件并避免上述异常,需确保应用程序配置文件中的参数设置无误: - **主机地址** (`spring.mail.host`) 和端口(`spring.mail.port`) 应匹配所使用的邮件服务提供商的要求; - 用户名(`spring.mail.username`) 必须是有效的电子邮箱账号; - 密码字段(`spring.mail.password`) 不应填写常规登录密码而是应该填入专门为此应用创建的应用专用密钥或授权码[^5]; - 协议(`spring.mail.protocol`) 设置为 `smtps` 或者其他支持SSL/TLS加密传输的方式; - 启用 SSL 加密连接(`spring.mail.properties.mail.smtp.ssl.enable=true`) 并确认拼写准确性 (注意原文中存在拼写错误 "ture")[^4]。 ```yaml spring: mail: host: smtp.example.com port: 465 username: user@example.com password: app_specific_password_or_authorization_code protocol: smtps properties: mail: smtp: ssl: enable: true ``` #### 获取正确的授权令牌 如果正在使用像Gmail, QQ Mail, 163 Mail这样的第三方服务商,则需要前往对应的官方网站获取相应的授权令牌而不是直接采用账户默认登陆密码作为输入项。例如,在某些情况下,用户可以在其个人资料的安全设置里找到生成新授权码的功能入口。 #### 测试连通性和调试日志 建议开启详细的日志记录以便更好地理解整个过程中的每一步骤,并利用测试工具如Telnet命令行工具来进行简单的SMTP会话模拟以检验基本网络层面上能否顺利建立通信链路。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值