SpringBoot で定期的にメールを送信する方法は何ですか?
一、发送邮件的三种方法
1、发送纯文本邮件
2、发送复杂邮件
3、发送模板邮件
二、定时任务介绍
Spring框架的定时任务调度功能支持配置和注解两种方式Spring Boot在Spring框架的基础上实现了继承,并对其中基于注解方式的定时任务实现了非常好的支持。下面,我们将介绍基于注解方式实现定时任务调度的相关注解和使用,适用于 Spring Boot 项目。
1.@EnableScheduling
@EnableScheduling 注解是 Spring 框架提供的,用于开启基于注解方式的定时任务支持,该注解主要用在项目启动类上。
2.@Scheduled
@Scheduled 注解同样是 Spring 框架提供的,配置定时任务的执行规则,该注解主要用在定时业务方法上。使用 @Scheduled 注解可以灵活配置定时任务的执行规则,其属性多样,能够实现精细化的调度
属性 | 说明 |
cron | 类似于 cron 的表达式,可以定制定时任务触发的秒、分钟、小时、月中的日、月、周中的日 |
zone | 表示在上一次任务执行结束后在指定时间后继续执行下一次任务(属性值为long类型) |
fixedDelay | 指定cron 表达式将被解析的时区。默认情况下,该属性是空字符串(即使用服务器的本地时区 |
fixedDelayString | 表示在上一次任务执行结束后在指定时间后继续执行下一次任务(属性值为long类型的字符串形式) |
fixedRate | 表示每隔指定时间执行一次任务 (属性值为 long 类型) |
fixedRateString | 表示每隔指定时间执行一次任务(属性值为 long 类型的字符串形式) |
initialDelay | 表示在fixedRate 或fixedDelay 任务第一次执行之前要延迟的毫秒数(属性值为long类型) |
initialDelayString | 表示在fixedRate或fixedDelay 任务第一次执行之前要延迟的毫秒数(属性值为long类型的字符串形式) |
三、前期准备工作
1、登录QQ邮箱获取授权码
第一步:进入QQ邮箱
第二步:找到POP3/SMTP,并开启
第三步:复制授权码
开启过程需要手机号码验证,按照步骤操作即可。开启成功之后,即可获取一个授权码,将该号码保存好,一会使用
2、pom.xml中的依赖
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <!--添加下面的依赖后,Spring Boot自动配置的邮件服务会生效,在邮件发送任务时, 可以直接使用Spring框架提供的JavaMailSender接口或者它的实现类JavaMailSenderImpl邮件 发送--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-mail</artifactId> </dependency> </dependencies>
3、在全局配置文件application.properties添加邮件服务配置
# 发件人邮件服务器相关配置 spring.mail.host=smtp.qq.com spring.mail.port=587 # 配置个人QQ账户和密码(这里需要大家修改为自己的QQ账号和密码,密码是加密后的授权码,授权码的获得后继讲解) spring.mail.username=QQ@qq.com spring.mail.password=填入刚刚复制的授权码 spring.mail.default-encoding=UTF-8 # 邮件服务超时时间配置 spring.mail.properties.mail.smtp.connectiontimeout=5000 spring.mail.properties.mail.smtp.timeout=3000 spring.mail.properties.mail.smtp.writetimeout=5000
四、操作
一、创建邮件发送任务管理的业务处理类SendEmailService
注意:在方法上的注解@Async是需要搭配定时任务一起使用的,如果使用普通的test类时可以不用这个注解的
package com.lyn.service; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.core.io.FileSystemResource; import org.springframework.mail.MailException; import org.springframework.mail.SimpleMailMessage; import org.springframework.mail.javamail.JavaMailSenderImpl; import org.springframework.mail.javamail.MimeMessageHelper; import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; import javax.mail.MessagingException; import javax.mail.internet.MimeMessage; import java.io.File; /** * @author:Lyn.R * @date:2023-02-21 14:54:36 * @Description: * @note: **/ @Service public class SendEmailService { @Autowired private JavaMailSenderImpl mailSender;//使用Spring框架提供的实现类JavaMailSenderImpl来实现邮件发送。 @Value("${spring.mail.username}")//借助@Value注解读取全局变量中的spring.mail.username的值来作发件人 private String from; /** * 第一种方法:发送纯文本邮件 * @param to 收件人地址 * @param subject 邮件标题 * @param text 邮件内容 */ @Async public void sendSimpleEmail(String to, String subject, String text) { // 定制纯文本邮件信息SimpleMailMessage SimpleMailMessage message = new SimpleMailMessage(); message.setFrom(from);//设置发件人 message.setTo(to);//设置收件人 message.setSubject(subject);//设置邮件标题 message.setText(text);//设置 正文件内容 try { // 发送邮件 mailSender.send(message); System.out.println("纯文本邮件发送成功"); } catch (MailException e) { System.out.println("纯文本邮件发送失败 " + e.getMessage()); e.printStackTrace(); } } /** * 第二种方法:发送复杂邮件(包括静态资源和附件) * @param to 收件人地址 * @param subject 邮件标题 * @param text 邮件内容 * @param filePath 附件地址 * @param rscId 静态资源唯一标识 * @param rscPath 静态资源地址 */ //sendComplexEmail()方法需要接收的参数除了基本的发送信息外,还包括静态资源唯一标识、静态资源路径和附件路径 @Async public void sendComplexEmail(String to,String subject,String text,String filePath,String rscId,String rscPath){ // 定制复杂邮件信息MimeMessage MimeMessage message = mailSender.createMimeMessage(); try { // 使用MimeMessageHelper帮助类对邮件信息封装处理 ,并设置multipart多部件使用为true MimeMessageHelper helper = new MimeMessageHelper(message, true); helper.setFrom(from); helper.setTo(to); helper.setSubject(subject); helper.setText(text, true); // 设置邮件静态资源 FileSystemResource res = new FileSystemResource(new File(rscPath)); helper.addInline(rscId, res);//设置邮件静态资源的方法 // 设置邮件附件 FileSystemResource file = new FileSystemResource(new File(filePath)); String fileName = filePath.substring(filePath.lastIndexOf(File.separator)); helper.addAttachment(fileName, file);//设置邮件附件的方法 // 发送邮件 mailSender.send(message); System.out.println("复杂邮件发送成功"); } catch (MessagingException e) { System.out.println("复杂邮件发送失败 "+e.getMessage()); e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } } /** * 第三钟方法:发送模板邮件 * @param to 收件人地址 * @param subject 邮件标题 * @param content 邮件内容 */ @Async public void sendTemplateEmail(String to, String subject, String content) { MimeMessage message = mailSender.createMimeMessage(); try { // 使用MimeMessageHelper帮助类对邮件信息进行封装处理,并设置multipart多部件使用为true MimeMessageHelper helper = new MimeMessageHelper(message, true); helper.setFrom(from); helper.setTo(to); helper.setSubject(subject); helper.setText(content, true); // 发送邮件 mailSender.send(message); System.out.println("模板邮件发送成功"); } catch (MessagingException e) { System.out.println("模板邮件发送失败 "+e.getMessage()); e.printStackTrace(); } } }
二、在test类中发送邮件
package com.lyn; import com.lyn.service.SendEmailService; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.thymeleaf.TemplateEngine; import org.thymeleaf.context.Context; @SpringBootTest class SpringbootHomeworkEmail0221ApplicationTests { @Autowired private SendEmailService sendEmailService; @Test public void sendSimpleMailTest() { String to="12345678@qq.com";//这里修改为你能接收到的邮箱 String subject="【纯文本邮件】标题"; String text="嘟嘟嘟....."; // 发送简单邮件 sendEmailService.sendSimpleEmail(to,subject,text); } @Test public void sendComplexEmailTest() { //根据前面定义的复杂邮件发送业务定制各种参数 String to="12345678@qq.com";//修改为你自己的邮件方便接收查看 String subject="【复杂邮件】标题"; // 定义邮件内容 StringBuilder text = new StringBuilder(); //对邮件内容使用了HTML标签编辑邮件内容 text.append("<html><head></head>"); text.append("<body><h2 id="二月二龙抬头">二月二龙抬头!</h2>"); // cid为嵌入静态资源文件关键字的固定写法,如果改变将无法识别;rscId则属于自定义的静态资源唯一标识,一个邮件内容中可能会包括多个静态资源,该属性是为了区别唯一性的。 String rscId = "img001"; text.append("<img src='cid:" +rscId+"'/ alt="SpringBoot で定期的にメールを送信する方法は何ですか?" ></body>"); text.append("</html>"); // 指定静态资源文件和附件路径 String rscPath="D:\\1.jpg";//注意这里修改为你的硬盘中有的资源 String filePath="D:\\hahaha.txt";//注意这里修改为你的硬盘中有的资源 // 发送复杂邮件 sendEmailService.sendComplexEmail(to,subject,text.toString(),filePath,rscId,rscPath); } @Autowired private TemplateEngine templateEngine; @Test public void sendTemplateEmailTest() { String to="12345678@qq.com"; String subject="【模板邮件】标题"; // 使用模板邮件定制邮件正文内容 Context context = new Context();//Context注意正确导入“import org.thymeleaf.context.Context;” context.setVariable("username", "石头"); context.setVariable("code", "456123"); // 使用TemplateEngine设置要处理的模板页面 String emailContent = templateEngine.process("emailTemplate_vercode", context); // 发送模板邮件 sendEmailService.sendTemplateEmail(to,subject,emailContent); } }
模板文件的html(emailTemplate_vercode.html)
<!DOCTYPE html> <html lang="en"> <html lang="zh" xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"/> <title>用户验证码</title> </head> <body> <div><span th:text="${username}">XXX</span> 先生/女士,您好:</div> <P >您的新用户验证码为<span th:text="$[code]" >123456</span>,请妥善保管。</P> </body> </html>
三、发送定时邮件
下面类中的 @Scheduled(cron = "*/5 * * * * ?")表达式大家可以去下面的网址生成Cron - 在线Cron表达式生成器 (ciding.cc)
package com.lyn.controller; import com.lyn.service.SendEmailService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Controller; import org.springframework.stereotype.Service; import org.thymeleaf.TemplateEngine; import org.thymeleaf.context.Context; /** * @author:Lyn.R * @date:2023-02-21 19:55:01 * @Description: * @note: **/ @Controller public class MyScheduled { @Autowired private SendEmailService sendEmailService; @Autowired //模板引擎(Template Engine), 是用来解析对应类型模板文件然后动态生成由数据和静态页面组成的视图文件的一个工具 private TemplateEngine templateEngine; @Scheduled(cron = "*/5 * * * * ?") public void sendSimpleMailTest() { String to="12345678@qq.com";//这里修改为你能接收到的邮箱 String subject="【纯文本邮件】标题"; String text="嘟嘟嘟....."; // 发送简单邮件 sendEmailService.sendSimpleEmail(to,subject,text); } @Scheduled(cron = "1 * * * * ? ") public void sendComplexEmailTest() { //根据前面定义的复杂邮件发送业务定制各种参数 String to="12345678@qq.com";//修改为你自己的邮件方便接收查看 String subject="【复杂邮件】标题"; // 定义邮件内容 StringBuilder text = new StringBuilder(); //对邮件内容使用了HTML标签编辑邮件内容 text.append("<html><head></head>"); text.append("<body><h2 id="二月二龙抬头">二月二龙抬头!</h2>"); // cid为嵌入静态资源文件关键字的固定写法,如果改变将无法识别;rscId则属于自定义的静态资源唯一标识,一个邮件内容中可能会包括多个静态资源,该属性是为了区别唯一性的。 String rscId = "img001"; text.append("<img src='cid:" +rscId+"'/ alt="SpringBoot で定期的にメールを送信する方法は何ですか?" ></body>"); text.append("</html>"); // 指定静态资源文件和附件路径 String rscPath="D:\\1.jpg";//注意这里修改为你的硬盘中有的资源 String filePath="D:\\hahaha.txt";//注意这里修改为你的硬盘中有的资源 // 发送复杂邮件 sendEmailService.sendComplexEmail(to,subject,text.toString(),filePath,rscId,rscPath); } @Scheduled(cron = "0 * * * * ? ") public void sendTemplateEmailTest() { String to="12345678@qq.com"; String subject="【模板邮件】标题"; // 使用模板邮件定制邮件正文内容 Context context = new Context();//Context注意正确导入“import org.thymeleaf.context.Context;” context.setVariable("username", "石头"); context.setVariable("code", "456123"); // 使用TemplateEngine设置要处理的模板页面 String emailContent = templateEngine.process("emailTemplate_vercode", context); // 发送模板邮件 sendEmailService.sendTemplateEmail(to,subject,emailContent); } }
四、在项目启动类上添加基于注解的定时任务支持:@EnableScheduling
package com.lyn; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.scheduling.annotation.EnableScheduling; @SpringBootApplication @EnableScheduling public class SpringbootHomeworkEmail0221Application { public static void main(String[] args) { SpringApplication.run(SpringbootHomeworkEmail0221Application.class, args); } }
注意:邮件发多了,可能会导致qq邮箱认为是垃圾邮件,就会出现报错,所以尽量不要进行邮箱轰炸。
以上がSpringBoot で定期的にメールを送信する方法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Jasypt の概要 Jasypt は、開発者が最小限の労力で基本的な暗号化機能を自分のプロジェクトに追加できる Java ライブラリであり、暗号化の仕組みを深く理解する必要はありません。一方向および双方向暗号化の高いセキュリティ。標準ベースの暗号化テクノロジー。パスワード、テキスト、数値、バイナリを暗号化します... Spring ベースのアプリケーション、オープン API への統合、JCE プロバイダーでの使用に適しています... 次の依存関係を追加します: com.github.ulisesbocchiojasypt-spring-boot-starter2. 1.1 Jasypt の特典はシステムのセキュリティを保護し、コードが漏洩した場合でもデータ ソースは保証されます。

使用シナリオ 1. 注文は正常に行われましたが、支払いが 30 分以内に行われませんでした。支払いがタイムアウトになり、注文が自動的にキャンセルされました 2. 注文に署名があり、署名後 7 日間評価が行われませんでした。注文がタイムアウトして評価されない場合、システムはデフォルトでプラスの評価を設定します 3. 注文は正常に行われます。販売者が 5 分間注文を受け取らない場合、注文はキャンセルされます。 4. 配送がタイムアウトします。 SMS リマインダーをプッシュします... 遅延が長く、リアルタイム パフォーマンスが低いシナリオでは、タスク スケジュールを使用して定期的なポーリング処理を実行できます。例: xxl-job 今日は選択します

1. Redis は分散ロックの原則を実装しており、分散ロックが必要な理由 分散ロックについて話す前に、分散ロックが必要な理由を説明する必要があります。分散ロックの反対はスタンドアロン ロックです。マルチスレッド プログラムを作成するとき、共有変数を同時に操作することによって引き起こされるデータの問題を回避します。通常、ロックを使用して共有変数を相互に除外し、データの正確性を確保します。共有変数の使用範囲は同じプロセス内です。共有リソースを同時に操作する必要があるプロセスが複数ある場合、どうすれば相互排他的になるのでしょうか?今日のビジネス アプリケーションは通常マイクロサービス アーキテクチャであり、これは 1 つのアプリケーションが複数のプロセスをデプロイすることも意味します。複数のプロセスが MySQL の同じレコード行を変更する必要がある場合、順序の乱れた操作によって引き起こされるダーティ データを避けるために、分散が必要です。今回導入するスタイルはロックされています。ポイントを獲得したい

Springboot はファイルを読み取りますが、jar パッケージにパッケージ化した後、最新の開発にアクセスできません。jar パッケージにパッケージ化した後、Springboot がファイルを読み取れない状況があります。その理由は、パッケージ化後、ファイルの仮想パスが変更されるためです。は無効であり、ストリーム経由でのみアクセスできます。読み取ります。ファイルはリソースの下にあります publicvoidtest(){Listnames=newArrayList();InputStreamReaderread=null;try{ClassPathResourceresource=newClassPathResource("name.txt");Input

Springboot+Mybatis-plus が SQL ステートメントを使用して複数テーブルの追加操作を実行しない場合、私が遭遇した問題は、テスト環境で思考をシミュレートすることによって分解されます: パラメーターを含む BrandDTO オブジェクトを作成し、パラメーターをバックグラウンドに渡すことをシミュレートします。 Mybatis-plus で複数テーブルの操作を実行するのは非常に難しいことを理解してください。Mybatis-plus-join などのツールを使用しない場合は、対応する Mapper.xml ファイルを設定し、臭くて長い ResultMap を設定するだけです。対応する SQL ステートメントを記述します。この方法は面倒に見えますが、柔軟性が高く、次のことが可能です。

SpringBoot と SpringMVC はどちらも Java 開発で一般的に使用されるフレームワークですが、それらの間には明らかな違いがいくつかあります。この記事では、これら 2 つのフレームワークの機能と使用法を調べ、その違いを比較します。まず、SpringBoot について学びましょう。 SpringBoot は、Spring フレームワークに基づいたアプリケーションの作成と展開を簡素化するために、Pivotal チームによって開発されました。スタンドアロンの実行可能ファイルを構築するための高速かつ軽量な方法を提供します。

1. RedisAPI のデフォルトのシリアル化メカニズムである RedisTemplate1.1 をカスタマイズします。API ベースの Redis キャッシュ実装では、データ キャッシュ操作に RedisTemplate テンプレートを使用します。ここで、RedisTemplate クラスを開いて、クラスのソース コード情報を表示します。publicclassRedisTemplateextendsRedisAccessorimplementsRedisOperations、BeanClassLoaderAware{//キーを宣言、値の各種シリアル化メソッド、初期値は空 @NullableprivateRedisSe

プロジェクトでは、構成情報が必要になることがよくありますが、この情報はテスト環境と本番環境で構成が異なる場合があり、実際のビジネス状況に基づいて後で変更する必要がある場合があります。これらの構成をコードにハードコーディングすることはできません。構成ファイルに記述することをお勧めします。たとえば、この情報を application.yml ファイルに書き込むことができます。では、コード内でこのアドレスを取得または使用するにはどうすればよいでしょうか?方法は2つあります。方法 1: @Value アノテーションが付けられた ${key} を介して、構成ファイル (application.yml) 内のキーに対応する値を取得できます。この方法は、マイクロサービスが比較的少ない状況に適しています。方法 2: 実際には、プロジェクト、業務が複雑な場合、ロジック
