Spring Boot實(shí)現(xiàn)自動發(fā)送郵件
研究此程序的前提是經(jīng)理給我安排的一個任務(wù),盯著每天的問號箱(跟公司的業(yè)務(wù)有關(guān),負(fù)責(zé)集裝箱管理的),只要一有產(chǎn)生,就立馬報告給另一個經(jīng)理,我當(dāng)時就想:如此機(jī)械性的操作、邏輯清晰明了,肯定是可以用程序來解決的。同時感嘆計算機(jī)的偉大,代碼真的是改變了我們的生活。
首先我們有一個問號箱管理的接口,此接口會實(shí)時性的產(chǎn)生問號箱的數(shù)據(jù),程序總的思路就是數(shù)據(jù)一有更新,立馬發(fā)送一條信息給經(jīng)理。原先我想到的是通過微信來發(fā)送信息,因為工作中就是通過它來傳達(dá)消息的,但是研究了一下,微信好像沒有提供這樣的API,無奈放棄微信,想到郵件肯定是有的,立馬搜到了一個純java寫的,主要用到的是javax.mail.jar包,動手寫了一下確實(shí)可以發(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層,這一段直接拷貝,謝謝那位大哥,搞得這么詳細(xì):
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è)置了獨(dú)立密碼(有的郵箱稱為“授權(quán)碼”), // 對于開啟了獨(dú)立密碼的郵箱, 這里的郵箱密碼必需使用這個獨(dú)立密碼(授權(quán)碼)。 @Value("${spring.mail.username}") public static String myEmailAccount = "****@163.com"; // @Value("${spring.mail.password}") public static String myEmailPassword = "********"; // 發(fā)件人郵箱的 SMTP 服務(wù)器地址, 必須準(zhǔn)確, 不同郵件服務(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"); // 需要請求認(rèn)證 // PS: 某些郵箱服務(wù)器要求 SMTP 連接需要使用 SSL 安全認(rèn)證 (為了提高安全性, 郵箱支持SSL連接, 也可以自己開啟), // 如果無法連接郵件服務(wù)器, 仔細(xì)查看控制臺打印的 log, 如果有有類似 “連接失敗, 要求 SSL 安全連接” 等錯誤, // 打開下面 /* ... */ 之間的注釋代碼, 開啟 SSL 安全連接。 /* // SMTP 服務(wù)器的端口 (非 SSL 連接的端口一般默認(rèn)為 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模式, 可以查看詳細(xì)的發(fā)送 log // 3. 創(chuàng)建一封郵件 MimeMessage message = createMimeMessage(session, myEmailAccount, receiveMailAccount,msg); // 4. 根據(jù) Session 獲取郵件傳輸對象 Transport transport = session.getTransport(); // 5. 使用 郵箱賬號 和 密碼 連接郵件服務(wù)器, 這里認(rèn)證的郵箱必須與 message 中的發(fā)件人郵箱一致, 否則報錯 // // PS_01: 成敗的判斷關(guān)鍵在此一句, 如果連接服務(wù)器失敗, 都會在控制臺輸出相應(yīng)失敗原因的 log, // 仔細(xì)查看失敗原因, 有些郵箱服務(wù)器會返回錯誤碼或查看錯誤類型的鏈接, 根據(jù)給出的錯誤 // 類型到對應(yīng)郵件服務(wù)器的幫助網(wǎng)站上查看具體失敗原因。 // // PS_02: 連接失敗的原因通常為以下幾點(diǎn), 仔細(xì)檢查代碼: // (1) 郵箱沒有開啟 SMTP 服務(wù); // (2) 郵箱密碼錯誤, 例如某些郵箱開啟了獨(dú)立密碼; // (3) 郵箱服務(wù)器要求必須要使用 SSL 安全連接; // (4) 請求過于頻繁或其他原因, 被郵件服務(wù)器拒絕服務(wù); // (5) 如果以上幾點(diǎn)都確定無誤, 到郵件服務(wù)器網(wǎng)站查找?guī)椭? // // PS_03: 仔細(xì)看log, 認(rèn)真看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ù)器誤認(rèn)為是濫發(fā)廣告以至返回失敗,請修改昵稱) message.setFrom(new InternetAddress(sendMail, "*******", "UTF-8")); // 3. To: 收件人(可以增加多個收件人、抄送、密送) message.setRecipient(MimeMessage.RecipientType.TO, new InternetAddress(receiveMail, "Dear", "UTF-8")); // 4. Subject: 郵件主題(標(biāo)題有廣告嫌疑,避免被郵件服務(wù)器誤認(rèn)為是濫發(fā)廣告以至返回失敗,請修改標(biāo)題) message.setSubject("問號箱信息 \n時間: "+new Date(), "UTF-8"); // 5. Content: 郵件正文(可以使用html標(biāo)簽)(內(nèi)容有廣告嫌疑,避免被郵件服務(wù)器誤認(rèn)為是濫發(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ā)了,另外還有一個實(shí)體類Message。好,右鍵項目Run As > Maven install 打包
打包完成。
jar包在target目錄下面,寫一個批處理運(yùn)行:java -jar SendMail-0.0.1-SNAPSHOT.jar pause
至此,程序已完成。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
rabbitmq使用springboot實(shí)現(xiàn)direct模式(最新推薦)
這篇文章主要介紹了rabbitmq使用springboot實(shí)現(xiàn)direct模式,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07Spring Boot中的WebSocketMessageBrokerConfigurer接口使用
在SpringBoot中,我們可以使用 WebSocketMessageBrokerConfigurer接口來配置WebSocket消息代理,以實(shí)現(xiàn)實(shí)時通信,具有一定的參考價值,感興趣的可以了解一下2023-11-11Java任務(wù)定時執(zhí)行器案例的實(shí)現(xiàn)
定時器會執(zhí)行指定的任務(wù),本文主要介紹了Java任務(wù)定時執(zhí)行器案例的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06Tree組件實(shí)現(xiàn)支持50W數(shù)據(jù)方法剖析
這篇文章主要為大家介紹了Tree組件實(shí)現(xiàn)支持50W數(shù)據(jù)的方法剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08