Spring Boot實現(xiàn)自動發(fā)送郵件
研究此程序的前提是經(jīng)理給我安排的一個任務(wù),盯著每天的問號箱(跟公司的業(yè)務(wù)有關(guān),負責(zé)集裝箱管理的),只要一有產(chǎn)生,就立馬報告給另一個經(jīng)理,我當時就想:如此機械性的操作、邏輯清晰明了,肯定是可以用程序來解決的。同時感嘆計算機的偉大,代碼真的是改變了我們的生活。
首先我們有一個問號箱管理的接口,此接口會實時性的產(chǎn)生問號箱的數(shù)據(jù),程序總的思路就是數(shù)據(jù)一有更新,立馬發(fā)送一條信息給經(jīng)理。原先我想到的是通過微信來發(fā)送信息,因為工作中就是通過它來傳達消息的,但是研究了一下,微信好像沒有提供這樣的API,無奈放棄微信,想到郵件肯定是有的,立馬搜到了一個純java寫的,主要用到的是javax.mail.jar包,動手寫了一下確實可以發(fā)送郵件,但是,我想把這個程序?qū)懗梢粋€接口,在前端代碼的配合下調(diào)用此接口。所以基于Maven搭建了一個SpringBoot框架,項目依賴:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>SendMail</groupId> <artifactId>SendMail</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.3.RELEASE</version> <relativePath /> </parent> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-mail</artifactId> </dependency> </dependencies> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <java.version>1.8</java.version> </properties> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
添加好依賴后項目名右鍵,java EE Tools > Generat Deployment Descriptor Stub ,然后Maven > Update Project 。
在src/main/resources目錄下手動添加application.properties文件,可以把郵箱的用戶名、密碼寫到這里,此處我只配置了項目的端口號,
server.port=10000。項目結(jié)構(gòu):

接下來就寫代碼,首先是程序啟動的代碼:
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@EnableAutoConfiguration
public class SendMailApplication {
public static void main(String[] args) {
SpringApplication.run(SendMailApplication.class, args);
}
}
接口層的代碼:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.domain.Message;
import com.service.MailService;
@RestController
@RequestMapping(value="/main")
public class Mail {
@Autowired
JavaMailSender mailSender;
@RequestMapping(value="/sendemail/{roadName}/{recordTime}/{truckName}",method = RequestMethod.GET )
public void sendEmail(@PathVariable(value = "roadName",required = true) String roadName,
@PathVariable(value = "recordTime",required = true) String recordTime,
@PathVariable(value = "truckName",required = true) String truckName)
{
try
{
Message msg = new Message(roadName,recordTime,truckName);
MailService.send(msg);
/* final MimeMessage mimeMessage = this.mailSender.createMimeMessage();
// final MimeMessageHelper message = new MimeMessageHelper(mimeMessage);
// message.setFrom("*********@163.com ");
// message.setTo("*******@qq.com");
// message.setSubject("測試郵件主題");
// message.setText("測試郵件內(nèi)容");
// this.mailSender.send(mimeMessage);
*/
}
catch(Exception ex)
{
}
}
注銷掉的部分為Springboot的郵件發(fā)送到的寫法,我沒用,接下來是我用到的寫法。service層,這一段直接拷貝,謝謝那位大哥,搞得這么詳細:
import java.util.Date;
import java.util.Properties;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import com.domain.Message;
@Service
public class MailService {
// 發(fā)件人的 郵箱 和 密碼(替換為自己的郵箱和密碼)
// PS: 某些郵箱服務(wù)器為了增加郵箱本身密碼的安全性,給 SMTP 客戶端設(shè)置了獨立密碼(有的郵箱稱為“授權(quán)碼”),
// 對于開啟了獨立密碼的郵箱, 這里的郵箱密碼必需使用這個獨立密碼(授權(quán)碼)。
@Value("${spring.mail.username}")
public static String myEmailAccount = "****@163.com";
//
@Value("${spring.mail.password}")
public static String myEmailPassword = "********";
// 發(fā)件人郵箱的 SMTP 服務(wù)器地址, 必須準確, 不同郵件服務(wù)器地址不同, 一般(只是一般, 絕非絕對)格式為: smtp.xxx.com
// 網(wǎng)易163郵箱的 SMTP 服務(wù)器地址為: smtp.163.com
public static String myEmailSMTPHost = "smtp.163.com";
// 收件人郵箱(替換為自己知道的有效郵箱)
public static String receiveMailAccount = "*****@126.com";
public static void send(Message msg) throws Exception {
// 1. 創(chuàng)建參數(shù)配置, 用于連接郵件服務(wù)器的參數(shù)配置
Properties props = new Properties(); // 參數(shù)配置
props.setProperty("mail.transport.protocol", "smtp"); // 使用的協(xié)議(JavaMail規(guī)范要求)
props.setProperty("mail.smtp.host", myEmailSMTPHost); // 發(fā)件人的郵箱的 SMTP 服務(wù)器地址
props.setProperty("mail.smtp.auth", "true"); // 需要請求認證
// PS: 某些郵箱服務(wù)器要求 SMTP 連接需要使用 SSL 安全認證 (為了提高安全性, 郵箱支持SSL連接, 也可以自己開啟),
// 如果無法連接郵件服務(wù)器, 仔細查看控制臺打印的 log, 如果有有類似 “連接失敗, 要求 SSL 安全連接” 等錯誤,
// 打開下面 /* ... */ 之間的注釋代碼, 開啟 SSL 安全連接。
/*
// SMTP 服務(wù)器的端口 (非 SSL 連接的端口一般默認為 25, 可以不添加, 如果開啟了 SSL 連接,
// 需要改為對應(yīng)郵箱的 SMTP 服務(wù)器的端口, 具體可查看對應(yīng)郵箱服務(wù)的幫助,
// 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. 根據(jù)配置創(chuàng)建會話對象, 用于和郵件服務(wù)器交互
Session session = Session.getInstance(props);
session.setDebug(true); // 設(shè)置為debug模式, 可以查看詳細的發(fā)送 log
// 3. 創(chuàng)建一封郵件
MimeMessage message = createMimeMessage(session, myEmailAccount, receiveMailAccount,msg);
// 4. 根據(jù) Session 獲取郵件傳輸對象
Transport transport = session.getTransport();
// 5. 使用 郵箱賬號 和 密碼 連接郵件服務(wù)器, 這里認證的郵箱必須與 message 中的發(fā)件人郵箱一致, 否則報錯
//
// PS_01: 成敗的判斷關(guān)鍵在此一句, 如果連接服務(wù)器失敗, 都會在控制臺輸出相應(yīng)失敗原因的 log,
// 仔細查看失敗原因, 有些郵箱服務(wù)器會返回錯誤碼或查看錯誤類型的鏈接, 根據(jù)給出的錯誤
// 類型到對應(yīng)郵件服務(wù)器的幫助網(wǎng)站上查看具體失敗原因。
//
// PS_02: 連接失敗的原因通常為以下幾點, 仔細檢查代碼:
// (1) 郵箱沒有開啟 SMTP 服務(wù);
// (2) 郵箱密碼錯誤, 例如某些郵箱開啟了獨立密碼;
// (3) 郵箱服務(wù)器要求必須要使用 SSL 安全連接;
// (4) 請求過于頻繁或其他原因, 被郵件服務(wù)器拒絕服務(wù);
// (5) 如果以上幾點都確定無誤, 到郵件服務(wù)器網(wǎng)站查找?guī)椭?
//
// PS_03: 仔細看log, 認真看log, 看懂log, 錯誤原因都在log已說明。
transport.connect(myEmailAccount, myEmailPassword);
// 6. 發(fā)送郵件, 發(fā)到所有的收件地址, message.getAllRecipients() 獲取到的是在創(chuàng)建郵件對象時添加的所有收件人, 抄送人, 密送人
transport.sendMessage(message, message.getAllRecipients());
// 7. 關(guān)閉連接
transport.close();
}
/**
* 創(chuàng)建一封只包含文本的簡單郵件
*
* @param session 和服務(wù)器交互的會話
* @param sendMail 發(fā)件人郵箱
* @param receiveMail 收件人郵箱
* @return
* @throws Exception
*/
public static MimeMessage createMimeMessage(Session session, String sendMail, String receiveMail,Message msg) throws Exception {
// 1. 創(chuàng)建一封郵件
MimeMessage message = new MimeMessage(session);
// 2. From: 發(fā)件人(昵稱有廣告嫌疑,避免被郵件服務(wù)器誤認為是濫發(fā)廣告以至返回失敗,請修改昵稱)
message.setFrom(new InternetAddress(sendMail, "*******", "UTF-8"));
// 3. To: 收件人(可以增加多個收件人、抄送、密送)
message.setRecipient(MimeMessage.RecipientType.TO, new InternetAddress(receiveMail, "Dear", "UTF-8"));
// 4. Subject: 郵件主題(標題有廣告嫌疑,避免被郵件服務(wù)器誤認為是濫發(fā)廣告以至返回失敗,請修改標題)
message.setSubject("問號箱信息 \n時間: "+new Date(), "UTF-8");
// 5. Content: 郵件正文(可以使用html標簽)(內(nèi)容有廣告嫌疑,避免被郵件服務(wù)器誤認為是濫發(fā)廣告以至返回失敗,請修改發(fā)送內(nèi)容)
message.setContent("時間:"+msg.getRecordTime()+" 車號:"+msg.getTruckName()+" 道口:"+msg.getRoadName(), "text/html;charset=UTF-8");
// 6. 設(shè)置發(fā)件時間
message.setSentDate(new Date());
// 7. 保存設(shè)置
message.saveChanges();
return message;
}
前端主要是ajax調(diào)用接口,代碼不發(fā)了,另外還有一個實體類Message。好,右鍵項目Run As > Maven install 打包

打包完成。
jar包在target目錄下面,寫一個批處理運行:java -jar SendMail-0.0.1-SNAPSHOT.jar pause
至此,程序已完成。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
rabbitmq使用springboot實現(xiàn)direct模式(最新推薦)
這篇文章主要介紹了rabbitmq使用springboot實現(xiàn)direct模式,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07
Spring Boot中的WebSocketMessageBrokerConfigurer接口使用
在SpringBoot中,我們可以使用 WebSocketMessageBrokerConfigurer接口來配置WebSocket消息代理,以實現(xiàn)實時通信,具有一定的參考價值,感興趣的可以了解一下2023-11-11
Java任務(wù)定時執(zhí)行器案例的實現(xiàn)
定時器會執(zhí)行指定的任務(wù),本文主要介紹了Java任務(wù)定時執(zhí)行器案例的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
Tree組件實現(xiàn)支持50W數(shù)據(jù)方法剖析
這篇文章主要為大家介紹了Tree組件實現(xiàn)支持50W數(shù)據(jù)的方法剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08

