使用java调用Office365发送邮件的时候报如下错误:
com.sun.mail.smtp.SMTPSendFailedException:530 5.7.57 SMTP; Client was not authenticated to send anonymous mail duringMAIL FROM
atcom.sun.mail.smtp.SMTPTransport.issueSendCommand(SMTPTransport.java:2108)
atcom.sun.mail.smtp.SMTPTransport.mailFrom(SMTPTransport.java:1609)
atcom.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:1117)
atjavax.mail.Transport.send0(Transport.java:195)
atjavax.mail.Transport.send(Transport.java:124)
atcom.paraview.mail.MailSender.sendTextMail(MailSender.java:60)
atcom.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 = newMailSSLSocketFactory();
sf.setTrustAllHosts(true);
proper.put("mail.smtp.ssl.socketFactory",sf);
错误依旧啊!这个时候已经无力吐槽了,继续查,错误里面有一个错误是这个:
Caused by: javax.net.ssl.SSLException: Unrecognized SSLmessage, plaintext connection?
这个是什么错?
于是我又问了下度娘,结果度娘说这个配置mail.smtp.socketFactory.fallback要改成 true 。
于是我就改了配置
proper.put("mail.smtp.socketFactory.fallback","true");
神奇的事情发生了,真的发送成功了!
在这里留一个备份,方便以后参考!