javaMail学习(六)——使用javaMail给QQ邮箱账户发简单邮件时碰到的问题

javaMail给QQ邮箱发邮件碰到的异常 

在使用JavaMail给QQ邮箱发邮件的过程中虽然碰到了很多问题,但是总结起来大致可以分成一下几类:

第一类:smtp 服 务 未开 启(没有 授 权 码)

因为在用代码发邮件之前,我用的Foxmail添加了QQ邮箱账户,添加的时候报错:-ERR Please using authorized code to login. More information at http://service.mail.qq.com/cgi-bin/help?subtype=1&&id=28&&no=1001256

解决办法自然是开 启 服 务且获取 授 权 码。

 

第二类:邮箱账户错误、授权码错误、smpt服务器地址错误类。

症状有以下几个:

1、Invalid Addresses:

Java代码 

 收藏代码

  1. javax.mail.SendFailedException: Invalid Addresses;  
  2. nested exception is:  
  3. com.sun.mail.smtp.SMTPAddressFailedException: 550 xxxx@qq.com relay mail disabled.(from "xxxxx@qq.com" to "yyyyyy@qq.com" via "wjl.com")   
  4.   
  5. at com.sun.mail.smtp.SMTPTransport.rcptTo(SMTPTransport.java:1607)  
  6. at com.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:887)  
  7. at javax.mail.Transport.send0(Transport.java:191)  
  8. at javax.mail.Transport.send(Transport.java:120)  
  9. at com.wjl.mail.utils.MailUtils.sendMain(MailUtils.java:64)  
  10. at com.wjl.mail.utils.MailUtils.main(MailUtils.java:71)  
  11. Caused by: com.sun.mail.smtp.SMTPAddressFailedException: 550 xxxx@qq.com relay mail disabled.(from "xxxxx@qq.com" to "yyyyyy@qq.com" via "wjl.com")   
  12.   
  13. at com.sun.mail.smtp.SMTPTransport.rcptTo(SMTPTransport.java:1458)  
  14. ... 5 more  

 我这个错误是smtp.host配置错误,因为本地的不用配置,而使用Q Q 邮 箱 是需要配置的。

2、535 Error: ��ʹ����Ȩ���¼�������뿴

Java代码 

 收藏代码

  1. 535 Error: ��ʹ����Ȩ���¼�������뿴: http://service.mail.qq.com/cgi-bin/help?subtype=1&&id=28&&no=1001256  
  2. javax.mail.AuthenticationFailedException: 535 Error: ÇëʹÓÃÊÚȨÂëµÇ¼¡£ÏêÇéÇë¿´: http://service.mail.qq.com/cgi-bin/help?subtype=1&&id=28&&no=1001256  
  3.   
  4.     at com.sun.mail.smtp.SMTPTransport$Authenticator.authenticate(SMTPTransport.java:648)  
  5.     at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:583)  
  6.     at javax.mail.Service.connect(Service.java:313)  
  7.     at javax.mail.Service.connect(Service.java:172)  
  8.     at javax.mail.Service.connect(Service.java:121)  
  9.     at javax.mail.Transport.send0(Transport.java:190)  
  10.     at javax.mail.Transport.send(Transport.java:120)  
  11.     at com.wjl.mail.utils.MailUtils.sendMain(MailUtils.java:76)  
  12.     at com.wjl.mail.utils.MailUtils.main(MailUtils.java:83)  

异常代码中的连接指向的是获取QQ邮箱 授 权 码,顾名思义这是授 权 码 错 误。

值得一提的是:

当mail.host写成smtp.exmail.qq.com时它也会报这个错,所以host必须写成smtp.qq.com。

获取授权码时QQ虽说一个邮箱账号可以拥有多个授权码,但是据本人测试,只有最近一个才有效。我开始申请了一个授权码,使用JavaMail发邮件能成功,后来授权码忘记了又申请了一个,使用老的授权码发送邮件失败,报错也是535Error,换成新的之后才发送成功。

因此一定要确保:QQ邮箱账户与授权码配套,授权码使用最新的,mail.host使用smtp.qq.com。

 

第三类:端口号错误

QQ邮箱的SMTP服务器官方上说的端口号465或587(查看

当端口号设置为587时将报错:Could not connect to SMTP host: smtp.qq.com, port: 587;

Java代码 

 收藏代码

  1. javax.mail.MessagingException: Could not connect to SMTP host: smtp.qq.com, port: 587;  
  2. nested exception is:  
  3.     javax.net.ssl.SSLException: Unrecognized SSL message, plaintext connection?  
  4.     at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1706)  
  5.     at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:525)  
  6.     at javax.mail.Service.connect(Service.java:291)  
  7.     at javax.mail.Service.connect(Service.java:172)  
  8.     at javax.mail.Service.connect(Service.java:192)  
  9.     at com.wjl.mail.utils.MailUtils.sendMain(MailUtils.java:92)  
  10.     at com.wjl.mail.utils.MailUtils.main(MailUtils.java:104)  
  11. Caused by: javax.net.ssl.SSLException: Unrecognized SSL message, plaintext connection?  
  12.     at com.sun.net.ssl.internal.ssl.InputRecord.handleUnknownRecord(InputRecord.java:652)  
  13.     at com.sun.net.ssl.internal.ssl.InputRecord.read(InputRecord.java:484)  
  14.     at com.sun.net.ssl.internal.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:863)  
  15.     at com.sun.net.ssl.internal.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1188)  
  16.     at com.sun.net.ssl.internal.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1215)  
  17.     at com.sun.net.ssl.internal.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1199)  
  18.     at com.sun.mail.util.SocketFetcher.configureSSLSocket(SocketFetcher.java:503)  
  19.     at com.sun.mail.util.SocketFetcher.getSocket(SocketFetcher.java:234)  
  20.     at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1672)  
  21.     ... 6 more  

因此还是使用465比较好。

 

第四类:未开 启 SSL加 密

症状有好几个:

1、530 Error: A secure connection is requiered(such as ssl)

2、debug中最后一行:"DEBUG SMTP: trying to connect to host "smtp.qq.com", port 465, isSSL false",一直都是这一行,程序也没有停止,一直都是这一行

3、javax.mail.AuthenticationFailedException: 220 Ready to start TLS

4、使用Foxmail添加QQ账户时,若不勾选"SSL",点击“创建”按钮后就一直处于“验证中.....”

解决办法:

Foxmail是勾选SSL,

javaMail中是添加如下代码:

Java代码 

 收藏代码

  1. //开 启SSL加密,否则会失败  
  2. MailSSLSocketFactory sf = new MailSSLSocketFactory();  
  3. sf.setTrustAllHosts(true);  
  4. props.put("mail.smtp.ssl.enable", "true");  
  5. props.put("mail.smtp.ssl.socketFactory", sf);  

 

第五类:莫名其妙类

症状:jks not found

Java代码 

 收藏代码

  1. java.security.KeyStoreException: problem accessing trust storejava.security.KeyStoreException: jks not found  
  2.     at com.sun.net.ssl.internal.ssl.TrustManagerFactoryImpl.engineInit(Unknown Source)  
  3.     at javax.net.ssl.TrustManagerFactory.init(Unknown Source)  
  4.     at com.sun.mail.util.MailSSLSocketFactory$MailTrustManager.<init>(MailSSLSocketFactory.java:329)  
  5.     at com.sun.mail.util.MailSSLSocketFactory$MailTrustManager.<init>(MailSSLSocketFactory.java:319)  
  6.     at com.sun.mail.util.MailSSLSocketFactory.<init>(MailSSLSocketFactory.java:111)  
  7.     at com.sun.mail.util.MailSSLSocketFactory.<init>(MailSSLSocketFactory.java:90)  
  8.     at com.wjl.mail.utils.SendSimpleMail.<clinit>(SendSimpleMail.java:52)  

为什么说是莫名其妙啊?因为这类问题在此处感觉就不应该出现,可就是出来了,很莫名其妙。

解决办法也很怪:重装jdk或者换jdk。我这里是换的jdk。我这个项目的JRE System Library先前用的jre6(jre目录:D:\Java\jre6),报这个错,后来改成jdk(JDK安装目录:D:\Java\jdk1.6.0_45)就不报错了,再换成jre6依旧报错。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值