今天是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");
神奇的事情发生了,真的发送成功了!
在这里留一个备份,方便以后参考!