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是類型驅動的注入,而@Resource是名稱驅動的注入,所以前者存在多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/") // 這里可以設置用戶點擊模版消息后,跳轉訪問的網(wǎng)址 .build(); //3,這里配置推送信息的標題和內容,以及它們的文字顏色 templateMessage.addData(new WxMpTemplateData("title", title, "#FF00FF")); templateMessage.addData(new WxMpTemplateData("message", message, "#FF00FF")); try { wxMpService.getTemplateMsgService().sendTemplateMsg(templateMessage); log.info("微信消息推送成功,消息標題:{},消息內容:{},推送給的用戶openid:{},模板id:{}", title, message, userOpenId, messageTemplateId); return "推送成功"; } catch (Exception e) { log.error("推送失?。簕},消息標題:{},消息內容:{},推送給的用戶openid:{},模板id:{}", e.getMessage(), return "推送失敗"; } } }
各個配置項例如appId和secret等都需要在application.yml中配置,然后用@Value注解將我們配置文件的屬性讀出來,我這里是偷懶了
到此這篇關于SpringBoot實現(xiàn)發(fā)送郵件、發(fā)送微信公眾號推送功能的文章就介紹到這了,更多相關SpringBoot發(fā)送郵件發(fā)送微信公眾號推送內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java實現(xiàn)根據(jù)前端所要格式返回樹形3級層級數(shù)據(jù)
這篇文章主要為大家詳細介紹了Java如何實現(xiàn)根據(jù)前端所要格式返回樹形3級層級數(shù)據(jù),文中的示例代碼講解詳細,有需要的小伙伴可以了解下2024-02-02Spring中@ExceptionHandler注解的工作原理詳解
這篇文章主要介紹了Spring中@ExceptionHandler注解的工作原理詳解,Spring Web注解@ExceptionHandler可以用來指定處理某類異常的控制器方法,從而在這些異常發(fā)生時,會有相應的控制器方法來處理此類異常,需要的朋友可以參考下2024-01-01Shiro 控制并發(fā)登錄人數(shù)限制及登錄踢出的實現(xiàn)代碼
本文通過shiro實現(xiàn)一個賬號只能同時一個人使用,本文重點給大家分享Shiro 控制并發(fā)登錄人數(shù)限制及登錄踢出的實現(xiàn)代碼,需要的朋友參考下吧2017-09-09