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,獲得授權(quán)碼。
需在application.yml中加入的配置如下:
spring:
mail:
host: smtp.qq.com
username: xxxxxxxx@qq.com
# 這個不是QQ密碼,而是自己郵箱-賬戶-開啟POP3/SMTP時的客戶端授權(quán)碼
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è)置郵件參數(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);
// 設(shè)置發(fā)件人
mimeMessageHelper.setFrom(from);
// 設(shè)置收件人
mimeMessageHelper.setTo(email);
// 設(shè)置郵件主題
mimeMessageHelper.setSubject(subject);
// 設(shè)置發(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:

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

這樣我們就能得到關(guān)注了此公眾號的用戶的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();
// 設(shè)置appId和secret
wxStorage.setAppId("xxxxxx");
wxStorage.setSecret("xxxxxxxxx");
WxMpService wxMpService = new WxMpServiceImpl();
wxMpService.setWxMpConfigStorage(wxStorage);
// 設(shè)置消息模板的templateID
String messageTemplateId = "xxxxxxxxxxx";
//2,推送消息
WxMpTemplateMessage templateMessage = WxMpTemplateMessage.builder()
.toUser(userOpenId) // 要推送的用戶openid
.templateId(messageTemplateId) // 模版id
// .url("https://www.xxxxx.com/xxxxxx/") // 這里可以設(shè)置用戶點擊模版消息后,跳轉(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注解將我們配置文件的屬性讀出來,我這里是偷懶了
到此這篇關(guān)于SpringBoot實現(xiàn)發(fā)送郵件、發(fā)送微信公眾號推送功能的文章就介紹到這了,更多相關(guān)SpringBoot發(fā)送郵件發(fā)送微信公眾號推送內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
并發(fā)編程之Java內(nèi)存模型volatile的內(nèi)存語義
這篇文章主要介紹了并發(fā)編程之Java內(nèi)存模型volatile的內(nèi)存語義,理解volatile特性的一個好辦法是把對volatile變量的單個讀/寫,看成是使用同一個鎖對單個讀/寫操作做了同步。下面我們一起進入文章看看具體例子吧,需要的小伙伴可以參考下2021-11-11
Spring源碼之事件監(jiān)聽機制詳解(@EventListener實現(xiàn)方式)
這篇文章主要介紹了Spring源碼之事件監(jiān)聽機制(@EventListener實現(xiàn)方式),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
hotspot解析jdk1.8?Unsafe類park和unpark方法使用
這篇文章主要為大家介紹了hotspot解析jdk1.8?Unsafe類park和unpark方法使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01

