Java Mail 實現第三方郵件發送功能


 

  1 創建一個用於發送郵件的類

  1 package com.latiny.service;
  2 
  3 import java.io.IOException;
  4 import java.io.InputStream;
  5 import java.util.Date;
  6 import java.util.Properties;
  7 import javax.mail.Session;
  8 import javax.mail.Transport;
  9 import javax.mail.internet.InternetAddress;
 10 import javax.mail.internet.MimeMessage;
 11 
 12 public class SendMail {
 13     
 14      /*
 15       1 發件人的 郵箱 和 密碼
 16       2 某些郵箱服務器為了增加郵箱本身密碼的安全性,給 SMTP 客戶端設置了獨立密碼(有的郵箱稱為"授權碼"), 
 17       3 對於開啟了獨立密碼的郵箱, 這里的郵箱密碼必需使用這個獨立密碼(授權碼)。
 18      */
 19     private String sendEmail;
 20     private String password;
 21    
 22     //發件人郵箱的 SMTP服務器地址, 必須准確, 不同郵件服務器地址不同, 一般(只是一般, 絕非絕對)格式為: smtp.xxx.com
 23     private String host;
 24     
 25     //收件人郵箱
 26     private String receiveEmail;
 27     
 28     // 發送主題,發送內容
 29     private String subject;
 30     private String content;
 31     
 32     //讀取配置文件
 33     private Properties pp;
 34     InputStream inStream;
 35     
 36     //從系統的配置文件取值給成員變量賦值
 37     private void initVariable()
 38     {
 39         pp = new Properties();
 40         inStream = SendMail.class.getClassLoader().getResourceAsStream("com/latiny/service/emailConfig.properties");
 41         try 
 42         {
 43             pp.load(inStream);
 44             sendEmail = pp.getProperty("sendEmail");
 45             password = pp.getProperty("password");
 46             host = pp.getProperty("host");
 47             
 48         } catch (IOException e) {
 49             // TODO Auto-generated catch block
 50             e.printStackTrace();
 51         }
 52     }
 53     
 54     public SendMail(String receiveEmail, String subject, String content)
 55     {
 56         this.subject = subject;
 57         this.receiveEmail = receiveEmail;
 58         this.content = content;
 59         initVariable();
 60         sendOut();
 61     }
 62     
 63     private MimeMessage createMessage(Session session, String subject, String content) throws Exception
 64     {
 65         // 創建郵件對象
 66         MimeMessage message = new MimeMessage(session);
 67         
 68         // 設置發件人
 69         message.setFrom(new InternetAddress(sendEmail, "訂單成功", "UTF-8"));
 70         
 71         // 收件人(可以增加多個收件人、抄送、密送)
 72         message.setRecipient(MimeMessage.RecipientType.TO, new InternetAddress(receiveEmail, "Latiny 用戶", "UTF-8"));
 73         
 74         // 郵件主題
 75         message.setSubject(subject, "UTF-8");
 76         
 77         // Content: 郵件正文(可以使用html標簽)
 78         message.setContent(content, "text/html;charset=UTF-8");
 79         
 80         // 置發件時間
 81         message.setSentDate(new Date());
 82 
 83         // 保存設置
 84         message.saveChanges();
 85         
 86         return message;
 87     }
 88 
 89     private void sendOut()
 90     {
 91         
 92         try 
 93         {
 94             // 創建參數配置, 用於連接郵件服務器的參數配置
 95             Properties props = new Properties();                    // 參數配置
 96             props.setProperty("mail.transport.protocol", "smtp");   // 使用的協議(JavaMail規范要求)
 97             props.setProperty("mail.smtp.host", host);               // 發件人的郵箱的 SMTP 服務器地址
 98             props.setProperty("mail.smtp.auth", "true");            // 需要請求認證
 99             
100             // PS: 某些郵箱服務器要求 SMTP 連接需要使用 SSL 安全認證 (為了提高安全性, 郵箱支持SSL連接, 也可以自己開啟),
101             // 如果無法連接郵件服務器, 仔細查看控制台打印的 log, 如果有有類似 “連接失敗, 要求 SSL 安全連接” 等錯誤,
102             // 打開下面 /* ... */ 之間的注釋代碼, 開啟 SSL 安全連接。
103             // SMTP 服務器的端口 (非 SSL 連接的端口一般默認為 25, 可以不添加, 如果開啟了 SSL 連接,需要改為對應郵箱的 SMTP 服務器的端口, 具體可查看對應郵箱服務的幫助,
104             // QQ郵箱的SMTP(SLL)端口為465或587, 其他郵箱自行去查看)
105             
106             /* 
107             final String smtpPort = "465";
108             props.setProperty("mail.smtp.port", smtpPort);
109             props.setProperty("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
110             props.setProperty("mail.smtp.socketFactory.fallback", "false");
111             props.setProperty("mail.smtp.socketFactory.port", smtpPort);
112             */
113             
114             //根據配置創建會話對象,用於和郵件服務器通信
115             Session session = Session.getInstance(props);
116             session.setDebug(true);
117             MimeMessage message = this.createMessage(session, this.subject, this.content);
118             
119              // 根據 Session 獲取郵件傳輸對象
120             Transport transport = session.getTransport();
121             
122             // 使用 郵箱賬號 和 密碼 連接郵件服務器, 這里認證的郵箱必須與 message 中的發件人郵箱一致, 否則報錯
123             // 
124             //    PS_01: 成敗的判斷關鍵在此一句, 如果連接服務器失敗, 都會在控制台輸出相應失敗原因的 log,
125             //           仔細查看失敗原因, 有些郵箱服務器會返回錯誤碼或查看錯誤類型的鏈接, 根據給出的錯誤
126             //           類型到對應郵件服務器的幫助網站上查看具體失敗原因。
127             //
128             //    PS_02: 連接失敗的原因通常為以下幾點, 仔細檢查代碼:
129             //           (1) 郵箱沒有開啟 SMTP 服務;
130             //           (2) 郵箱密碼錯誤, 例如某些郵箱開啟了獨立密碼;
131             //           (3) 郵箱服務器要求必須要使用 SSL 安全連接;
132             //           (4) 請求過於頻繁或其他原因, 被郵件服務器拒絕服務;
133             //           (5) 如果以上幾點都確定無誤, 到郵件服務器網站查找幫助。
134             //
135             //    PS_03: 仔細看log, 認真看log, 看懂log, 錯誤原因都在log已說明。
136             transport.connect(sendEmail,password);
137             
138             // 發送郵件, 發到所有的收件地址, message.getAllRecipients() 獲取到的是在創建郵件對象時添加的所有收件人, 抄送人, 密送人
139             transport.sendMessage(message, message.getAllRecipients());
140             
141             // 關閉連接
142             transport.close();
143             
144         } catch (Exception e) {
145             // TODO Auto-generated catch block
146             e.printStackTrace();
147         }
148     }
149     
150 }

 

  配置文件 emailConfig.properties:

sendEmail = XXX@163.com
password = email密碼,非登錄密碼,而是專門提供的授權碼
host =smtp.163.com

 

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM