解决530 5.7.57 SMTP; Client was not authenticated to send anonymous mail during MAIL FROM

吕嘉赐
2023-12-01

今天是1024,先祝各位码农节日快乐!   


使用java调用Office365发送邮件的时候报如下错误:

     com.sun.mail.smtp.SMTPSendFailedException: 530 5.7.57 SMTP; Client was not authenticated to send anonymous mail during MAIL FROM

    at com.sun.mail.smtp.SMTPTransport.issueSendCommand(SMTPTransport.java:2108)
    at com.sun.mail.smtp.SMTPTransport.mailFrom(SMTPTransport.java:1609)
    at com.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:1117)
    at javax.mail.Transport.send0(Transport.java:195)
    at javax.mail.Transport.send(Transport.java:124)
    at com.paraview.mail.MailSender.sendTextMail(MailSender.java:60)
    at com.paraview.mail.Test.main(Test.java:10)


分割线------------------------------------------------------------------------------------------------

    刚开始我以为是配置错误,因为代码都是在网上找的,复制粘贴而已,现在的程序员都懒 ,我更懒!但是我的代码是之前在其他项目中正常运行过的,也就是说我的代码是正常的,但是为何调用office365就会报错呐?

   我尝试了在网上寻找大牛的解决办法,google了几个小时后没有结果,虽然有很多人遇到同样的问题,但是老外给的解决办法也是各种各样,结果是都没有解决我遇到的问题。

   

 邮箱配置如下:

    SMTP 设置

    服务器名称: smtp.outlook.cn

   端口: 587

    加密方法: TLS

  我通过Foxmail配置后是可以正常收发邮件的,为何通过代码不可以呐?

  从邮箱配置上我可以看到加密方法: TLS ,TLS不是SSL  所以我在我的配置上加上了配置   proper.put("mail.smtp.starttls.enable", "true");

 然后继续运行,发现错误不一样了


这个错误又是为何?不能通过TLS建立连接,但是明明是TLS啊。网上有一些blog说必须是jdk1.6不能是jdk1.7虽然搞不明白为何,但是索性也把jdk版本换了

结果错误依旧啊!

这个时候索性我就想干脆把所有的配置都加上,看看什么效果,于是我就又加了如下配置:

proper.put("mail.smtp.socketFactory.class","javax.net.ssl.SSLSocketFactory");
proper.put("mail.smtp.socketFactory.port","587");
        proper.put("mail.smtp.socketFactory.fallback", "false")


这个时候错误又变了:Could not connect to SMTP host: smtp.partner.outlook.cn, port: 587;为何连不上578端口,端口是肯定没问题,一定是 配置有问题

  于是我又加上了配置:

      MailSSLSocketFactory sf = new MailSSLSocketFactory(); 
      sf.setTrustAllHosts(true); 
proper.put("mail.smtp.ssl.socketFactory", sf);

错误依旧啊!这个时候已经无力吐槽了,继续查,错误里面有一个错误是这个:

Caused by: javax.net.ssl.SSLException: Unrecognized SSL message, plaintext connection?

这个是什么错?

于是我又问了下度娘,结果度娘说 这个配置mail.smtp.socketFactory.fallback要改成 true 。

于是我就改了配置 proper.put("mail.smtp.socketFactory.fallback", "true"); 


神奇的事情发生了,真的发送成功了!


在这里留一个备份,方便以后参考!




 






 类似资料: