java語言實現發送email案例

1.引入jar包。只引入javax.mail- api 包不全會報錯。
<dependency> 包不全會報錯 
           <groupId >javax.mail </groupId >  
           <artifactId >javax.mail- api</ artifactId>  
           <version >1.5.1 </version >  
           <scope >test </scope >  
         </dependency>
應該引入:
<dependency >  
      <groupId >javax.mail </groupId >  
      <artifactId >mail </artifactId >  
      <version >1.4.5 </version >  
      </dependency >  
      <dependency >  
      <groupId >com.sun.mail </groupId >  
      <artifactId >javax.mail </artifactId >  
      <version >1.5.4 </version >  
    </dependency >

2.創建SendMailUtil工具類(該類主要:1.配置郵箱服務器api參數。2.創建一封只包含文本的簡單郵件)

import javax.mail.MessagingException;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.Date;
import java.util.Properties;
public class SendMailUtil {
	/*發件人的 郵箱 和 密碼
    某些郵箱服務器爲了增加郵箱本身密碼的安全性,給 SMTP 客戶端設置了獨立密碼(有的郵箱稱爲“授權碼”), 
    對於開啓了獨立密碼的郵箱, 這裏的郵箱密碼必需使用這個獨立密碼(授權碼)。 
	授權密碼 通過QQ郵箱設置->賬戶->POP3/IMAP/SMTP/Exchange/CardDAV/CalDAV服務->開啓POP3/SMTP服務獲取*/
    public static String myEmailAccount = "[email protected]"; 
    public static String myEmailPassword = "gc123456"; 

    // 發件人郵箱的 SMTP 服務器地址一般格式爲: smtp.xxx.com 
    // 網易163郵箱的 SMTP 服務器地址爲: smtp.163.com 
    public static String myEmailSMTPHost = "smtp.163.com"; 

    // 收件人郵箱(替換爲自己知道的有效郵箱)
    //String receiveMailAccount = "[email protected]";在controller層調用sendMail()時傳入receiveMailAccount
    public static void sendMail(String receiveMailAccount) throws Exception{ 
        // 1. 創建參數配置, 用於連接郵件服務器的參數配置 
        Properties props = new Properties();                    // 參數配置 
        props.setProperty("mail.transport.protocol", "smtp");   // 使用的協議(JavaMail規範要求) 
        props.setProperty("mail.smtp.host", myEmailSMTPHost);   // 發件人的郵箱的 SMTP 服務器地址 
        props.setProperty("mail.smtp.auth", "true");            // 需要請求認證 

        // PS: 某些郵箱服務器要求 SMTP 連接需要使用 SSL 安全認證 (爲了提高安全性, 郵箱支持SSL連接, 也可以自己開啓), 
        //     如果無法連接郵件服務器, 仔細查看控制檯打印的 log, 如果有有類似 “連接失敗, 要求 SSL 安全連接” 等錯誤, 
        //     打開下面 /* ... */ 之間的註釋代碼, 開啓 SSL 安全連接。 
        /* 
        // SMTP 服務器的端口 (非 SSL 連接的端口一般默認爲 25, 可以不添加, 如果開啓了 SSL 連接, 
        //                  需要改爲對應郵箱的 SMTP 服務器的端口, 具體可查看對應郵箱服務的幫助, 
        //                  QQ郵箱的SMTP(SLL)端口爲465或587, 其他郵箱自行去查看) 
        final String smtpPort = "465"; 
        props.setProperty("mail.smtp.port", smtpPort); 
        props.setProperty("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory"); 
        props.setProperty("mail.smtp.socketFactory.fallback", "false"); 
        props.setProperty("mail.smtp.socketFactory.port", smtpPort); 
        */ 

        // 2. 根據配置創建會話對象, 用於和郵件服務器交互 
        Session session = Session.getDefaultInstance(props); 
        session.setDebug(true);                                 // 設置爲debug模式, 可以查看詳細的發送 log 

        // 3. 創建一封郵件 
        MimeMessage message = createMimeMessage(session, myEmailAccount, 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(myEmailAccount, myEmailPassword); 

        // 6. 發送郵件, 發到所有的收件地址, message.getAllRecipients() 獲取到的是在創建郵件對象時添加的所有收件人, 抄送人, 密送人 
        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, "guochuang", "UTF-8")); 

        // 3. To: 收件人(可以增加多個收件人、抄送、密送) 
        message.setRecipient(MimeMessage.RecipientType.TO, new InternetAddress(receiveMail, "用戶:"+receiveMailAccount, "UTF-8")); 
        // TODO 密文發送等
        
        // 4. Subject: 郵件主題 
        message.setSubject("javaMail測試內容", "UTF-8"); 

        // 5. Content: 郵件正文(可以使用html標籤) 
        message.setContent("郵件正文:驗證郵箱後獲取聯繫方式,姓名:guo", "text/html;charset=UTF-8"); 

        // 6. 設置發件時間 
        message.setSentDate(new Date()); 

        // 7. 保存設置 
        message.saveChanges(); 

        return message; 
    } 
}

3.在controller層調用工具類方法:
         /**
	 * 郵箱驗證
	 * @param request
	 * @return
	 */
	@RequestMapping(value="/sendMail",method=RequestMethod.POST,produces="text/html;charset=utf-8")
	@ResponseBody
	public Object sendMail(HttpServletRequest request){
		JSONObject data=new JSONObject();
		String receiveMailAccount=request.getParameter("receiveMailAccount");
		try {
			SendMailUtil.sendMail(receiveMailAccount);
			data.put(data, "發送成功!");
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
			data.put(data, "發送失敗!");
		}
		return data.toString();
		
	}





發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章