栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

十一、SpringBoot与任务

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

十一、SpringBoot与任务

任务

一、异步任务二、定时任务

1. cron表达式(例:"0 * * * * MON-FRI")2.编码测试 三、邮件任务

1.引入maven依赖2.自动配置原理3. 配置文件4.简单邮件发送测试5.自定义邮件发送

一、异步任务

在系统设计中,有时会出现某个任务相对耗时无法立即返回执行结果,这是如果使用同步的方法系统会一直等待加载,非常影响用户体验和执行效率,这时我们可以使用异步任务;正常使用异步任务我们会编写大量异步代码,会加重编码任务,也会影响代码可读性,这里,SpringBoot使用@Async注解简化了编码需求;

    service层
    @Service
    public class AsynService {
    
        @Async
        public void hello(){
            try {
                Thread.sleep(3000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println("数据处理中。。。" );
        }
    }
    
    controller层
    @RestController
    public class AsynController {
    
        @Autowired
        private AsynService asynService;
    
        @GetMapping("/hello")
        public String hello(){
            asynService.hello();
            return "success";
        }
    }
    
    启动类
    @EnableAsync//开启异步注解
    @SpringBootApplication
    public class Springboot04TaskApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(Springboot04TaskApplication.class, args);
        }
    
    }
    

注意:必须在启动类加上@EnableAsync注解,不然@Async注解不起作用;

二、定时任务

项目开发中经常需要一些定时任务,比如需啊哟在每天凌晨时候,分析一次前一天的日志信息。spring为我们提供了异步执行任务调度的方式,提供TaskExcutor、TaskScheduler接口;SpringBoot提供了@EnableScheduler和@Scheduled两个接口方便进行操作;

1. cron表达式(例:“0 * * * * MON-FRI”)
    表达式说明:
字段允许值允许的特殊字符
0-59, - * /
0-59, - * /
小时0-23, - * /
日期1-31, - * ? / L W C
月份1-12, - * /
星期0-7或SUN-SAT 0,7是SUN, - * ? / L C #
    特殊字符说明:
特殊字符代表含义
枚举
-区间
*任意
/步长
日/星期冲突匹配
L最后
W工作日
C和calendar联系后计算过的值
#星期,4#2,第二个星期三

3.示例说明:

[0 0/5 14,18 * * ?] 每天14点整和18点整,每隔5分钟执行一次
[0 15 10 ? * 1-6] 每个月的周一至周六10:15分执行一次
[0 0 2 ? * 6L] 每个月的最后一个周六凌晨2点执行一次
[0 0 2 LW * ?] 每个月的最后一个工作日凌晨2点执行一次
[0 0 2-4 ? * 1#1]每个月的第一周一凌晨2点到4点期间,每个整点都执行一次

2.编码测试
    service层
    @Service
    public class SchedulerService {
    
        
        @Scheduled(cron = "0 * * * * MON-FRI")
        public void hello(){
            System.out.println("hello...");
        }
    }
    
    启动类
    @EnableAsync//开启异步注解
    @EnableScheduling//开启基于注解的定时任务
    @SpringBootApplication
    public class Springboot04TaskApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(Springboot04TaskApplication.class, args);
        }
    
    }
    

注意:必须在启动类加上@EnableScheduling注解,不然@Scheduled注解不起作用;

三、邮件任务

我们这里演示将邮件从QQ邮箱发送邮件到163邮箱;

1.引入maven依赖
 
     org.springframework.boot
     spring-boot-starter-mail
 
2.自动配置原理

MailSenderPropertiesConfiguration中配置了JavaMailSenderImpl的Bean作为邮件发送的核心类使用;
MailProperties作为mail发送的配置类;

3. 配置文件
spring:
  mail:
    username: 2510530603@qq.com
    password: vvjzovlkcohndjdj
    host: smtp.qq.com

QQ邮箱发送邮件需要打开ssl安全配置

spring.mail.properties.mail.smtp.ssl.enable=true
4.简单邮件发送测试
    @Autowired
    JavaMailSender mailSender;

    @Test
    void contextLoads() {
        final SimpleMailMessage message = new SimpleMailMessage();
        //邮件设置
        message.setSubject("通知-今晚开会");
        message.setText("今晚7:30开会");
        message.setTo("yarm_he@163.com");
        message.setFrom("2510530603@qq.com");
        mailSender.send(message);
    }
5.自定义邮件发送
    @Autowired
    JavaMailSender mailSender;
    
    @Test
    void contextLoads2() throws MessagingException {
        //1.创建一个复杂的消息邮件
        final MimeMessage mimeMessage = mailSender.createMimeMessage();
        final MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true);
        //邮件设置
        helper.setSubject("通知-今晚开会");
        //设置邮件内容的样式
        helper.setText("今晚7:30开会",true);
        helper.setTo("yarm_he@163.com");
        helper.setFrom("2510530603@qq.com");
        //发送文件
        helper.addAttachment("1.jpg",new File("E:\照片视频\mmexport1607997781226.jpg"));
        helper.addAttachment("1.jpg",new File("E:\照片视频\mmexport1607997784015.jpg"));
        mailSender.send(mimeMessage);
    }
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/778829.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号