SpringBoot实现发送邮件、发送微信公众号推送

SpringBoot实现发送邮件、发送微信公众号推送

SpringBoot实现发送邮件

  JavaMailSender是Spring封装的邮件发送封装类,支持普通文本、附件、html等格式。

pom.xml
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-mail</artifactId>
        </dependency>
application.yml

  我们这里用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
    properties:
      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的问题。

SpringBoot实现发送微信公众号推送

  我们需要登录微信公众号测试平台,获取appID和appsecret,并在模板消息接口中新建模板,获得模板ID:
在这里插入图片描述
  然后让需要接收信息推送的人都关注测试公众号:
在这里插入图片描述
  这样我们就能得到关注了此公众号的用户的openid(微信号):
在这里插入图片描述

pom.xml

  这里我们使用微信模版消息推送三方sdk:

        <dependency>
            <groupId>com.github.binarywang</groupId>
            <artifactId>weixin-java-mp</artifactId>
            <version>3.3.0</version>
        </dependency>
代码实现
@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/") // 这里可以设置用户点击模版消息后,跳转访问的网址
				.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(),
					title, message, userOpenId, messageTemplateId);
			return "推送失败";
		}
	}
}

  各个配置项例如appId和secret等都需要在application.yml中配置,然后用@Value注解将我们配置文件的属性读出来,我这里是偷懒了

  • 1
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

happy19991001

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值