/*
* <dependency >
<groupId >com.sun.mail </groupId >
<artifactId >javax.mail </artifactId >
<version >1.5.4 </version >
</dependency >
*/
/*上面是maven需要添加的依賴*/
package com.weiling.wl_erp.util;
import org.springframework.beans.factory.annotation.Value;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import java.util.Date;
import java.util.Properties;
/**
* 作者:王懷朋
* 日期:2019/9/26
*/
public class MailUtil {
//sendEmailAccount:發件人郵箱
//receiveMailAccount:收件人郵箱
//sendEmailPwd :發件人郵箱密碼
// PS: 某些郵箱服務器為了增加郵箱本身密碼的安全性,給 SMTP 客戶端設置了獨立密碼(有的郵箱稱為“授權碼”),
// 對於開啟了獨立密碼的郵箱, 這里的郵箱密碼必需使用這個獨立密碼(授權碼)。
//打開郵箱-->上方找到設置 -->賬戶 -->找到(POP3/IMAP/SMTP/Exchange/CardDAV/CalDAV服務)-->開啟pop3 -->獲得授權碼;
public static String sendEmailAccount = "1055665333@qq.com";
public static String receiveMailAccount = "401968297@qq.com";
public static String sendEmailPwd = "郵箱登陸授權碼";
//發件人郵箱服務器地址
public static String emailProtocolType = "smtp";
public static String sendEmailSMTPHost = "smtp.qq.com";
public static String smtpPort = "465";
public static String sslSocketFactory = "javax.net.ssl.SSLSocketFactory";
public static String prt;
// 發件人郵箱的 SMTP 服務器地址, 必須准確, 不同郵件服務器地址不同, 一般格式為: smtp.xxx.com
// 網易163郵箱的 SMTP 服務器地址為: smtp.163.com
// 收件人郵箱(替換為自己知道的有效郵箱)
public static void main(String[] args) throws Exception {
// 1. 創建參數配置, 用於連接郵件服務器的參數配置
Properties props = new Properties(); // 參數配置
props.setProperty("mail.transport.protocol", emailProtocolType); // 使用的協議(JavaMail規范要求)
props.setProperty("mail.smtp.host", sendEmailSMTPHost); // 發件人的郵箱的 SMTP 服務器地址
props.setProperty("mail.smtp.auth", "true"); // 需要請求認證
props.put("mail.smtp.ssl.enable", "true");
//ssl安全認證
props.setProperty("mail.smtp.port", smtpPort);
//設置socketfactory
props.setProperty("mail.smtp.socketFactory.class", sslSocketFactory);
//只處理SSL的連接, 對於非SSL的連接不做處理
props.setProperty("mail.smtp.socketFactory.fallback", "false");
props.setProperty("mail.smtp.socketFactory.port", smtpPort);
// 2. 根據配置創建會話對象, 用於和郵件服務器交互
Session session = Session.getInstance(props);
session.setDebug(true); // 設置為debug模式, 可以查看詳細的發送 log
// 3. 創建一封郵件
MimeMessage message = createMimeMessage(session, sendEmailAccount, receiveMailAccount);
// 4. 根據 Session 獲取郵件傳輸對象
Transport transport = session.getTransport();
// 5. 使用 郵箱賬號 和 密碼 連接郵件服務器, 這里認證的郵箱必須與 message 中的發件人郵箱一致, 否則報錯
//
// PS_01: 成敗的判斷關鍵在此一句, 如果連接服務器失敗, 都會在控制台輸出相應失敗原因的 log,
// 仔細查看失敗原因, 有些郵箱服務器會返回錯誤碼或查看錯誤類型的鏈接, 根據給出的錯誤
// 類型到對應郵件服務器的幫助網站上查看具體失敗原因。
//
// PS_02: 連接失敗的原因通常為以下幾點, 仔細檢查代碼:
// (1) 郵箱沒有開啟 SMTP 服務;
// (2) 郵箱密碼錯誤, 例如某些郵箱開啟了獨立密碼;
// (3) 郵箱服務器要求必須要使用 SSL 安全連接;
// (4) 請求過於頻繁或其他原因, 被郵件服務器拒絕服務;
// (5) 如果以上幾點都確定無誤, 到郵件服務器網站查找幫助。
//
// PS_03: 仔細看log, 認真看log, 看懂log, 錯誤原因都在log已說明。
transport.connect(sendEmailAccount, sendEmailPwd);
// 6. 發送郵件, 發到所有的收件地址, message.getAllRecipients() 獲取到的是在創建郵件對象時添加的所有收件人, 抄送人, 密送人
System.out.println(message+"===================="+message.getAllRecipients()+"======"+prt);
transport.sendMessage(message,message.getAllRecipients());
// 7. 關閉連接
transport.close();
}
/**
* 創建一封只包含文本的簡單郵件
*
* @param session 和服務器交互的會話
* @param sendMail 發件人郵箱
* @param receiveMail 收件人郵箱
* @return
* @throws Exception
*/
public static MimeMessage createMimeMessage(Session session, String sendMail, String receiveMail) throws Exception {
// 1. 創建一封郵件
MimeMessage message = new MimeMessage(session);
// 2. From: 發件人(昵稱有廣告嫌疑,避免被郵件服務器誤認為是濫發廣告以至返回失敗,請修改昵稱)
message.setFrom(new InternetAddress(sendMail, "setFrom", "UTF-8"));
// 3. To: 收件人(可以增加多個收件人、抄送、密送)
// CC:抄送人,BCC:密送
message.setRecipient(MimeMessage.RecipientType.TO, new InternetAddress(receiveMail, "1055665333@qq.com", "UTF-8"));
// 4. Subject: 郵件主題(標題有廣告嫌疑,避免被郵件服務器誤認為是濫發廣告以至返回失敗,請修改標題)
message.setSubject("你是賤人嗎", "UTF-8");
// 5. Content: 郵件正文(可以使用html標簽)(內容有廣告嫌疑,避免被郵件服務器誤認為是濫發廣告以至返回失敗,請修改發送內容)
message.setContent("我看是的", "text/html;charset=utf-8");
// 6. 設置發件時間
message.setSentDate(new Date());
// 7. 保存設置
message.saveChanges();
return message;
}
}