Spring Boot+RabbitMQ 通过fanout模式实现消息接收功能(支持消费者多实例部署)
474
2022-08-19
SpringBoot实现发送邮件、发送微信公众号推送功能
SpringBoot实现发送邮件
javaMailSender是Spring封装的邮件发送封装类,支持普通文本、附件、html等格式。
pom.xml
application.yml
&emcqfUhssp; 我们这里用QQ邮箱发送邮件作为例子,首先需要在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
propertieshttp://:
mail:
smtp:
auth:
starttls:
# 需要TLS认证 保证发送邮件安全验证
enable: true
required: true
代码实现
带附件的格式发送邮件需要借助JavaMailSender对象的createMimeMessage()方法创建的实例MimeMessage作为发送对象,而设置邮件参数通过MimeMessageHelper对象完成。 我们创建EmailUtil工具类,在其中定义sendMail方法进行邮件发送,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);
// 设置发件人
mimeMessageHelper.setFrom(from);
// 设置收件人
mimeMessageHelper.setTo(email);
// 设置邮件主题
mimeMessageHelper.setSubject(subject);
// 设置发送的文本信息
mimeMessageHelper.setText(text);
javaMailSender.send(mimeMessage);
return true;
} catch (MessagingException e) {
e.printStackTrace();
return false;
}
}
}
这里对成员变量JavaMailSender使用了@Resource注解。@Resource注解和@Autowired注解类似,都用来声明需要自动装配的bean,区别在于@Autowired是类型驱动的注入,而@Resource是名称驱动的注入,所以前者存在多bean问题,而后者,只要保证bean命名唯一就不会出现多bean的问题。
pom.xml
这里我们使用微信模版消息推送三方sdk:
代码实现
@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://xxxxx.com/xxxxxx/") // 这里可以设置用户点击模版消息后,跳转访问的网址
.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注解将我们配置文件的属性读出来,我这里是偷懒了
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~