一. 发送邮件原理
发件人【设置授权码】 - SMTP协议【Simple Mail TransferProtocol - 是一种提供可靠且有效的电子邮件传输的协议】 - 收件人
二. 获取授权码
开通POP3/SMTP,获取授权码
授权码是QQ邮箱推出的,用于登录第三方客户端的专用密码。适用于登录以下服务:POP3/IMAP/SMTP/Exchange/CardDAV/CalDAV服务。
温馨提醒:为了你的帐户安全,更改QQ密码以及独立密码会触发授权码过期,需要重新获取新的授权码登录
第一步:进入邮箱设置 -> 账户 -> 生成授权码 :【注意】POP3/SMTP ,IMAP/SMTP服务都需要开启
三. SpringBoot发送邮件步骤
1. 选择一个邮件服务商:QQ - smtp.qq.com
2. 获取授权码
3. 导包
4. 配置文件
5. 注入使用JavaMailSender
注意事项:163和126邮箱要检查邮件中是否有未许可的信息,所有最好用qq邮箱作为发送方。而且发送方邮箱账号就是配置中的邮箱账号
导入依赖
<!--对邮件的支持jar--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-mail</artifactId> </dependency>
配置邮箱
spring: servlet: multipart: #设置单个文件大小 max-file-size: 10MB #设置单次请求文件的总大小 max-request-size: 50MB mail: host: smtp.qq.com # 设置邮箱主机(服务商),这里使用QQ邮件服务器 username: 2399690261@qq.com # 设置用户名 - 发送方 password: axgjklvsrgoeeaie # 设置密码,该处的密码是QQ邮箱开启SMTP的授权码而非QQ密码 properties: mail: smtp: auth: true # 必须进行授权认证,它的目的就是阻止他人任意乱发邮件 starttls: #SMTP加密方式:连接到一个TLS保护连接 enable: true required: true
发送邮件测试类
package io.coderyeah; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.mail.SimpleMailMessage; import org.springframework.mail.javamail.JavaMailSender; import org.springframework.mail.javamail.MimeMessageHelper; import org.springframework.test.context.junit4.SpringRunner; import javax.annotation.Resource; import javax.mail.MessagingException; import javax.mail.internet.MimeMessage; import java.io.File; import java.util.Date; @SpringBootTest(classes = PetHomeApplication.class) @RunWith(SpringRunner.class) public class EmailTest { @Resource private JavaMailSender javaMailSender; /** * 发送简单邮件 */ @Test public void test1() { final SimpleMailMessage simpleMailMessage = new SimpleMailMessage(); // 设置发送人 simpleMailMessage.setFrom("2399690261@qq.com"); // 设置标题 simpleMailMessage.setSubject("新型冠状病毒防护指南"); // 设置文件内容 simpleMailMessage.setText("<h2>好好在家待着别到处乱跑噢.....</h2>"); // 设置发收件人 simpleMailMessage.setTo("3050105866@qq.com"); // 设置发送时间 simpleMailMessage.setSentDate(new Date()); // 发送邮件 javaMailSender.send(simpleMailMessage); } /** * 发送复杂文件 */ @Test public void test2() throws MessagingException { // 创建复杂邮件对象 final MimeMessage mimeMessage = javaMailSender.createMimeMessage(); // 发送复杂邮件工具类 true - 能够添加附件 MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true, "utf-8"); // 发件人 helper.setFrom("2399690261@qq.com"); // 邮件标题 helper.setSubject("店铺激活邮件"); // 邮件内容 true - 能够再内容中编写html标签 - 会解析 helper.setText("<h3>你的店铺已经审核通过,请<a href='http://localhost:8080/shop/active/40'>点击这里</a>激活邮件</h3>", true); //添加附件 helper.addAttachment("Java面试题大全.pdf",new File("C:\\Users\\coderyeah\\Desktop\\Java面试题大全.pdf")); helper.addAttachment("welt.jpg", new File("C:\\Users\\coderyeah\\Desktop\\welt.jpg")); //收件人 helper.setTo("3050105866@qq.com"); javaMailSender.send(mimeMessage); } }
业务代码
@Transactional @Override public Result pass(ShopAuditLog auditLog) throws MessagingException { // 1.店铺审核通过 将t_shop表状态修改为2表示审核通过待激活 final Shop shop = new Shop(); shop.setState(2); shopMapper.update(shop, new LambdaQueryWrapper<Shop>().eq(BaseDomain::getId, auditLog.getShopId())); // 2. 新增审核日志 auditLog.setAuditId(356L); // 审核人 auditLog.setState(2); auditLogMapper.insert(auditLog); // 3.发送激活邮件 复杂邮件 final MimeMessage mimeMessage = javaMailSender.createMimeMessage(); final MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true, "utf-8"); helper.setFrom("2399690261@qq.com"); helper.setSubject("店铺激活邮件"); helper.setText("<h3>你的店铺已经审核通过,请<a href='http://localhost:8080/shop/active/" + auditLog.getShopId() + "'><font color='blue'>点击这里</font></a>激活邮件</h3>", true); final Shop shop1 = shopMapper.selectById(auditLog.getShopId()); // 待激活店铺 // 店铺管理员 final Employee employee = employeeMapper.selectById(shop1.getAdminId()); helper.setTo(employee.getEmail()); //收件人 // 发送邮件 javaMailSender.send(mimeMessage); return Result.success(null); }