Javamail使用過程中常見問題解決方案
今天在研究javamail發(fā)信的過程中,出現(xiàn)了一些小問題,現(xiàn)總結(jié)如下,以免后來者走些不必要的彎路,先把完整的能夠正常運行的代碼示例粘貼如下:
發(fā)郵件源代碼:
import java.util.Properties; import javax.mail.*; import javax.mail.internet.*; public class MailExample { public static void main (String args[]) throws Exception { String host = "smtp.163.com"; //發(fā)件人使用發(fā)郵件的電子信箱服務(wù)器 String from = "你自己的電子信箱"; //發(fā)郵件的出發(fā)地(發(fā)件人的信箱) String to = "收件人信箱"; //發(fā)郵件的目的地(收件人信箱) // Get system properties Properties props = System.getProperties(); // Setup mail server props.put("mail.smtp.host", host); // Get session props.put("mail.smtp.auth", "true"); //這樣才能通過驗證 MyAuthenticator myauth = new MyAuthenticator("你自己的電子信箱", "你自己的信箱密碼"); Session session = Session.getDefaultInstance(props, myauth); //session.setDebug(true); // Define message MimeMessage message = new MimeMessage(session); // Set the from address message.setFrom(new InternetAddress(from)); // Set the to address message.addRecipient(Message.RecipientType.TO, new InternetAddress(to)); // Set the subject message.setSubject("測試程序!"); // Set the content message.setText("這是用java寫的發(fā)送電子郵件的測試程序!"); message.saveChanges(); Transport.send(message); } }
校驗發(fā)信人權(quán)限的方法
import javax.mail.PasswordAuthentication; class MyAuthenticator extends javax.mail.Authenticator { private String strUser; private String strPwd; public MyAuthenticator(String user, String password) { this.strUser = user; this.strPwd = password; } protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication(strUser, strPwd); } }
注意:上面的事例僅為使用163信箱時發(fā)送電子郵件的方法,因為使用的host為:smtp.163.com,如源代碼中:String host = "smtp.163.com"; //發(fā)件人使用發(fā)郵件的電子信箱服務(wù)器,如果使用其它的電子郵件發(fā)送,就必須在其郵件服務(wù)器上查找相應(yīng)的電子郵件服務(wù)器,例如搜狐就要使用smtp.sohu.com,具體情況具體對待,都可以從所使用的郵件服務(wù)器上獲得的。如果沒有使用host ,也就是說,沒有進行props.put("mail.smtp.host", host);設(shè)置,那么就會拋javax.mail.MessagingException: Could not connect to SMTP host: localhost, port: 25;的異常。當(dāng)然了,如果你沒有正確配置,這個異常仍然會被拋出的。
有些郵件服務(wù)系統(tǒng)是不需要驗證發(fā)件人的授權(quán)的,所以可以很簡單的使用
Session session = Session.getDefaultInstance(props, null);
// 而不必使用
props.put("mail.smtp.auth", "true");
MyAuthenticator myauth = new MyAuthenticator("你自己的電子信箱", "你自己的信箱密碼");
Session session = Session.getDefaultInstance(props, myauth);
就可以發(fā)送電子郵件了,這個多為一些企事業(yè)單位的內(nèi)部電子信箱系統(tǒng)。
但是對于很多門戶網(wǎng)站上的電郵系統(tǒng),如:163,sohu,yahoo等等,如果仍然簡單的這樣使用就會拋
com.sun.mail.smtp.SMTPSendFailedException: 553 authentication is required,smtp8,wKjADxuAyCAfmnZE8BwtIA==.32705S2
at com.sun.mail.smtp.SMTPTransport.issueSendCommand(SMTPTransport.java:1388)
at com.sun.mail.smtp.SMTPTransport.mailFrom(SMTPTransport.java:959)
at com.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:583)
at javax.mail.Transport.send0(Transport.java:169)
at javax.mail.Transport.send(Transport.java:98)
這樣的異常,要求你必須進行授權(quán)校驗,它的目的就是阻止他人任意亂發(fā)郵件,也算是為了減少垃圾郵件的出現(xiàn)吧。這時候,我們就要使用
props.put("mail.smtp.auth", "true");
MyAuthenticator myauth = new MyAuthenticator("你自己的電子信箱", "你自己的信箱密碼");
Session session = Session.getDefaultInstance(props, myauth);
這里還有一個特別注意的事情:在你使用Session.getDefaultInstance時,一定要將 props.put("mail.smtp.auth", "true"); 置為true,它默認(rèn)的是false,如果你沒有做這一步,雖然你使用了Session.getDefaultInstance(props, myauth);,你自己也確實 MyAuthenticator myauth = new MyAuthenticator("你自己的電子信箱", "你自己的信箱密碼");但是它仍然會拋出
com.sun.mail.smtp.SMTPSendFailedException: 553 authentication is required,smtp8,wKjADxJA2SBrm3ZEFv0gIA==.40815S2
at com.sun.mail.smtp.SMTPTransport.issueSendCommand(SMTPTransport.java:1388)
at com.sun.mail.smtp.SMTPTransport.mailFrom(SMTPTransport.java:959)
at com.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:583)
at javax.mail.Transport.send0(Transport.java:169)
at javax.mail.Transport.send(Transport.java:98)
這樣的異常。我就在這一步費了好長時間,后來才發(fā)現(xiàn)了這個問題,很是郁悶。不過還好,總算解決了。
其實上面的做法只是比較簡單的一種,也有很多其它的寫法,如:
Properties props = System.getProperties();可以使用
Properties props = new Properties();來代替。
Transport.send(message);可以使用下面的代碼來代替
String username = "你的電子信箱用戶名";
String password = "你的電子信箱密碼";
message.saveChanges(); // implicit with send()
Transport transport = session.getTransport("smtp");
transport.connect("mail.htf.com.cn", username, password);
transport.sendMessage(message, message.getAllRecipients());
transport.close();
這種方法在同時發(fā)送多封電子郵件時比較有用。
還有一些具體的相關(guān)概念,可以查看相關(guān)的官方文檔,在我查詢資料時,發(fā)現(xiàn)了一篇文章寫得相當(dāng)仔細(xì),可以加以參考:另附上使用org.apache.commons.mail進行發(fā)電子郵件的示例:
import org.apache.commons.mail.SimpleEmail; import org.apache.commons.mail.*; public class TestCommon { public TestCommon() { } public static void main(String[] args) { SimpleEmail email = new SimpleEmail(); email.setHostName("smtp.163.com");//設(shè)置使用發(fā)電子郵件的郵件服務(wù)器 try { email.addTo("收件人信箱"); email.setAuthentication("發(fā)件人信箱", "發(fā)件人信箱密碼"); email.setFrom("發(fā)件人信箱"); email.setSubject("Test apache.commons.mail message"); email.setMsg("This is a simple test of commons-email"); email.send(); } catch (EmailException ex) { ex.printStackTrace(); } } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringCloud?Function?SpEL注入漏洞分析及環(huán)境搭建
SpringCloud 是一套分布式系統(tǒng)的解決方案,常見的還有阿里巴巴的Dubbo,F(xiàn)ass的底層實現(xiàn)就是函數(shù)式編程,SpringCloud Function 就是Spring提供的分布式函數(shù)式編程組件,下面給大家介紹下SpringCloud?Function?SpEL注入漏洞分析,感興趣的朋友一起看看吧2022-04-04詳解JVM基礎(chǔ)之字節(jié)碼的增強技術(shù)
字節(jié)碼增強技術(shù)就是一類對現(xiàn)有字節(jié)碼進行修改或者動態(tài)生成全新字節(jié)碼文件的技術(shù)。接下來,我們將從最直接操縱字節(jié)碼的實現(xiàn)方式開始深入進行剖析,感興趣的可以了解一下2022-10-10java使用FastJson解析Json數(shù)據(jù)
本篇文章主要介紹了java使用FastJson解析Json數(shù)據(jù),fastjson 是一個性能極好的用 Java 語言實現(xiàn)的 JSON 解析器和生成器,有興趣的可以了解一下。2017-02-02java搭建一個Socket服務(wù)器響應(yīng)多用戶訪問
本篇文章主要介紹了java搭建一個Socket服務(wù)器響應(yīng)多用戶訪問,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02