Spring Boot實現(xiàn)發(fā)送郵件
在web開發(fā)中,發(fā)送郵件是一個很常用的功能,Spring Boot也集成了發(fā)送郵件的功能
基本使用使用Spring Boot的發(fā)送郵件功能,需要導(dǎo)入郵件的starter依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-mail</artifactId></dependency>
配置郵件發(fā)送服務(wù)器的配置,如果是qq郵箱,password屬性為郵箱的授權(quán)碼
spring: mail: host: smtp.qq.com username: 425017255@qq.com password: xxxxxxxx properties: mail.smtp.ssl.enable: true
創(chuàng)建一個簡單郵件對象SimpleMailMessage,設(shè)置郵件的主題,內(nèi)容,發(fā)件人和收件人,然后自動注入JavaMailSenderImpl對象,使用這個對象的send方法發(fā)送郵件
@SpringBootTestclass DemoApplicationTests { @Autowired JavaMailSenderImpl mailSender; @Test void contextLoads() {SimpleMailMessage message = new SimpleMailMessage();message.setSubject('測試郵件');message.setText('這是一封測試郵件');message.setTo('blackball1998@outlook.com');message.setFrom('425017255@qq.com');mailSender.send(message); }}
這樣就可以發(fā)送簡單郵件了
發(fā)送復(fù)雜郵件,可以使用發(fā)送類的createMimeMessage方法創(chuàng)建一個復(fù)雜郵件對象MimeMessage,這個方法還有一個重載方法,可以讀取IO流創(chuàng)建郵件對象
創(chuàng)建一個用于設(shè)置郵件的對象MimeMessageHelper,這個對象可以設(shè)置多種郵件的常用屬性,這里以設(shè)置附件為例
@SpringBootTestclass DemoApplicationTests { @Autowired JavaMailSenderImpl mailSender; @Test void contextLoads() throws MessagingException {MimeMessage message = mailSender.createMimeMessage();MimeMessageHelper messageHelper = new MimeMessageHelper(message, true, 'utf-8');messageHelper.setSubject('測試復(fù)雜郵件'); // 設(shè)置帶樣式的正文,使用html的方式設(shè)置樣式messageHelper.setText('<h1>這是一封測試郵件</h1><p style=’color:red’>請查收附件</p>',true); // 讀取本地的一個文件,設(shè)置郵件的附件messageHelper.addAttachment('附件1.jpg',new File('1.png'));messageHelper.addAttachment('附件2.jpg',new File('2.png'));messageHelper.setTo('blackball1998@outlook.com');messageHelper.setFrom('425017255@qq.com');mailSender.send(message); }}
設(shè)置好郵件的屬性,然后用發(fā)送類發(fā)送郵件,就可以收到復(fù)雜郵件
郵件中的附件也可以打開
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. CSS3實例分享之多重背景的實現(xiàn)(Multiple backgrounds)2. 低版本IE正常運行HTML5+CSS3網(wǎng)站的3種解決方案3. CSS Hack大全-教你如何區(qū)分出IE6-IE10、FireFox、Chrome、Opera4. HTML DOM setInterval和clearInterval方法案例詳解5. XML入門精解之結(jié)構(gòu)與語法6. css代碼優(yōu)化的12個技巧7. css進階學(xué)習(xí) 選擇符8. 告別AJAX實現(xiàn)無刷新提交表單9. HTML <!DOCTYPE> 標簽10. CSS hack用法案例詳解
