SpringBoot實現(xiàn)發(fā)送郵件、發(fā)送微信公眾號推送功能
SpringBoot實現(xiàn)發(fā)送郵件
JavaMailSender是Spring封裝的郵件發(fā)送封裝類,支持普通文本、附件、html等格式。
pom.xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-mail</artifactId>
</dependency>application.yml
我們這里用QQ郵箱發(fā)送郵件作為例子,首先需要在QQ郵箱中開啟POP3/SMTP,獲得授權碼。
需在application.yml中加入的配置如下:
spring:
mail:
host: smtp.qq.com
username: xxxxxxxx@qq.com
# 這個不是QQ密碼,而是自己郵箱-賬戶-開啟POP3/SMTP時的客戶端授權碼
password: xxxxxxxxx
default-encoding: utf-8
protocol: smtp
properties:
mail:
smtp:
auth:
starttls:
# 需要TLS認證 保證發(fā)送郵件安全驗證
enable: true
required: true代碼實現(xiàn)
帶附件的格式發(fā)送郵件需要借助JavaMailSender對象的createMimeMessage()方法創(chuàng)建的實例MimeMessage作為發(fā)送對象,而設置郵件參數(shù)通過MimeMessageHelper對象完成。
我們創(chuàng)建EmailUtil工具類,在其中定義sendMail方法進行郵件發(fā)送,EmailUtil完整代碼如下:
@Component
public class EmailUtil {
@Value("${spring.mail.username}")
private String from;
@Resource
private JavaMailSender javaMailSender;
public boolean sendMail(String email, String subject, String text) {
MimeMessage mimeMessage = javaMailSender.createMimeMessage();
try {
MimeMessageHelper mimeMessageHelper = new MimeMessageHelper(mimeMessage, true);
// 設置發(fā)件人
mimeMessageHelper.setFrom(from);
// 設置收件人
mimeMessageHelper.setTo(email);
// 設置郵件主題
mimeMessageHelper.setSubject(subject);
// 設置發(fā)送的文本信息
mimeMessageHelper.setText(text);
javaMailSender.send(mimeMessage);
return true;
} catch (MessagingException e) {
e.printStackTrace();
return false;
}
}
}這里對成員變量JavaMailSender使用了@Resource注解。@Resource注解和@Autowired注解類似,都用來聲明需要自動裝配的bean,區(qū)別在于@Autowired是類型驅(qū)動的注入,而@Resource是名稱驅(qū)動的注入,所以前者存在多bean問題,而后者,只要保證bean命名唯一就不會出現(xiàn)多bean的問題。
SpringBoot實現(xiàn)發(fā)送微信公眾號推送
我們需要登錄微信公眾號測試平臺,獲取appID和appsecret,并在模板消息接口中新建模板,獲得模板ID:

然后讓需要接收信息推送的人都關注測試公眾號:

這樣我們就能得到關注了此公眾號的用戶的openid(微信號):

pom.xml
這里我們使用微信模版消息推送三方sdk:
<dependency>
<groupId>com.github.binarywang</groupId>
<artifactId>weixin-java-mp</artifactId>
<version>3.3.0</version>
</dependency>代碼實現(xiàn)
@Component
public class WxUtils {
private Logger log = LoggerFactory.getLogger(getClass());
public String sendMessage(String title, String message, String userOpenId) {
//1,配置
WxMpInMemoryConfigStorage wxStorage = new WxMpInMemoryConfigStorage();
// 設置appId和secret
wxStorage.setAppId("xxxxxx");
wxStorage.setSecret("xxxxxxxxx");
WxMpService wxMpService = new WxMpServiceImpl();
wxMpService.setWxMpConfigStorage(wxStorage);
// 設置消息模板的templateID
String messageTemplateId = "xxxxxxxxxxx";
//2,推送消息
WxMpTemplateMessage templateMessage = WxMpTemplateMessage.builder()
.toUser(userOpenId) // 要推送的用戶openid
.templateId(messageTemplateId) // 模版id
// .url("https://www.xxxxx.com/xxxxxx/") // 這里可以設置用戶點擊模版消息后,跳轉(zhuǎn)訪問的網(wǎng)址
.build();
//3,這里配置推送信息的標題和內(nèi)容,以及它們的文字顏色
templateMessage.addData(new WxMpTemplateData("title", title, "#FF00FF"));
templateMessage.addData(new WxMpTemplateData("message", message, "#FF00FF"));
try {
wxMpService.getTemplateMsgService().sendTemplateMsg(templateMessage);
log.info("微信消息推送成功,消息標題:{},消息內(nèi)容:{},推送給的用戶openid:{},模板id:{}",
title, message, userOpenId, messageTemplateId);
return "推送成功";
} catch (Exception e) {
log.error("推送失?。簕},消息標題:{},消息內(nèi)容:{},推送給的用戶openid:{},模板id:{}", e.getMessage(),
return "推送失敗";
}
}
}各個配置項例如appId和secret等都需要在application.yml中配置,然后用@Value注解將我們配置文件的屬性讀出來,我這里是偷懶了
到此這篇關于SpringBoot實現(xiàn)發(fā)送郵件、發(fā)送微信公眾號推送功能的文章就介紹到這了,更多相關SpringBoot發(fā)送郵件發(fā)送微信公眾號推送內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
在java中由類名和方法名字符串實現(xiàn)其調(diào)用方式
這篇文章主要介紹了在java中由類名和方法名字符串實現(xiàn)其調(diào)用方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
Java實現(xiàn)根據(jù)前端所要格式返回樹形3級層級數(shù)據(jù)
這篇文章主要為大家詳細介紹了Java如何實現(xiàn)根據(jù)前端所要格式返回樹形3級層級數(shù)據(jù),文中的示例代碼講解詳細,有需要的小伙伴可以了解下2024-02-02
Spring中@ExceptionHandler注解的工作原理詳解
這篇文章主要介紹了Spring中@ExceptionHandler注解的工作原理詳解,Spring Web注解@ExceptionHandler可以用來指定處理某類異常的控制器方法,從而在這些異常發(fā)生時,會有相應的控制器方法來處理此類異常,需要的朋友可以參考下2024-01-01
Shiro 控制并發(fā)登錄人數(shù)限制及登錄踢出的實現(xiàn)代碼
本文通過shiro實現(xiàn)一個賬號只能同時一個人使用,本文重點給大家分享Shiro 控制并發(fā)登錄人數(shù)限制及登錄踢出的實現(xiàn)代碼,需要的朋友參考下吧2017-09-09

