迎着风跑  

一、SpringBoot单元测试

1、引入启动器

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-test</artifactId>
</dependency>

<font color=red>注意:不需要引入junit的jar包</font>

2、测试方式1

import org.junit.Test;

@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = {ApplicationApp.class})
public class MyTest {

   @Autowired
   private IUserService userService;

   @Test
   public void userTest(){
       System.out.println(userService.findUser());
  }
}

3、测试方式2


import org.junit.jupiter.api.Test;  //注意junit包名

@SpringBootTest
public class MyTest {

   @Autowired
   private IUserService userService;

   @Test
   public void userTest(){
       System.out.println(userService.findUser());
  }
}

<font color=red>提示:测试来必须和启动类在同一个包或子包下</font>

 

二、SpringBoot异常处理

1、默认方式

SpringBoot 默认的处理异常的机制:SpringBoot 默认的已经提供了一套处理异常的机制。一旦程序中出现了异常 SpringBoot 向src/main/resources/templates目录下的/error 的 url 发送请求。在 springBoot 中提供了一个叫 BasicErrorController 来处理/error 请求,然后跳转到默认显示异常的页面来展示异常信息。

  • 在src/main/resources/ templates创建error.html页面


    <!DOCTYPE html>
    <html xmlns:th="http://www.thymeleaf.org">
    <head>
       <meta charset="UTF-8">
       <title>错误提示页面</title>
    </head>
    <body>
    出错了,请与管理员联系。。。
    </body>
    </html>
  • 修改controller


    @Controller
    public class HelloController {
       @RequestMapping("show")
       public String showInfo(){
          int i=1/0;
           return "index";
      }
    }

    当我们在浏览器访问http://localhost/show时,会报异常,此时直接跳转到error.html页面

2、@ExceptionHandle 注解方式

在controller当前类中添加方法来捕获当前类抛出的异常,从而进行处理,该方法上添加@ExceptionHandler注解

  • 在resources/templates目录下创建error1.html页面


    <!DOCTYPE html>
    <html xmlns:th="http://www.thymeleaf.org">
    <head>
       <meta charset="UTF-8">
       <title>错误提示页面-ArithmeticException</title>
    </head>
    <body>
      出错了,请与管理员联系。。。
       <span th:text="${error}"></span>
    </body>
    </html>
  • 修改controller


    @Controller
    public class HelloController {
       @RequestMapping("show")
       public String showInfo(){
          int i=1/0;
           return "index";
      }

       /**
        * 异常处理方法
        * @param e
        * @return
        */
       @ExceptionHandler(value = {java.lang.ArithmeticException.class})
       public ModelAndView arithmeticExceptionHandler(Exception e) {
           ModelAndView model = new ModelAndView();
           model.addObject("error", e.toString());
           model.setViewName("error1");  //逻辑视图名
           return model;
      }
    }

3、@ControllerAdvice方式

自定义一个类GlobalException,并添加注解 @ControllerAdvice,或者@RestControllerAdvice, 在处理异常的方法上面添加@ExceptionHandler注解并在value中添加要处理的异常


@ControllerAdvice
public class GlobalException {
   /**
    * java.lang.ArithmeticException
    * 该方法需要返回一个 ModelAndView:目的是可以让我们封装异常信息以及视
    * 图的指定
    * 参数 Exception e:会将产生异常对象注入到方法中
    */
   @ExceptionHandler(value = {ArithmeticException.class})
   public ModelAndView arithmeticExceptionHandler(Exception e) {
       ModelAndView mv = new ModelAndView();
       mv.addObject("error", e.toString());
       mv.setViewName("error");
       return mv;
  }

   /**
    * java.lang.NullPointerException
    * 该方法需要返回一个 ModelAndView:目的是可以让我们封装异常信息以及视
    * 图的指定
    * 参数 Exception e:会将产生异常对象注入到方法中
    */
   @ExceptionHandler(value = {NullPointerException.class})
   public ModelAndView nullPointerExceptionHandler(Exception e) {
       ModelAndView mv = new ModelAndView();
       mv.addObject("error", e.toString());
       mv.setViewName("error1");
       return mv;
  }
}

4、全局异常解析器

自定义一个配置类,创建一个全局异常SimpleMappingExceptionResolver解析器的bean对象到spring容器中,有spring来管理


@Configuration
public class GlobalException {
   /**
    * 该方法必须要有返回值。返回值类型必须是:
    * SimpleMappingExceptionResolver
    */
   @Bean
   public SimpleMappingExceptionResolver getSimpleMappingExceptionResolver() {
       SimpleMappingExceptionResolver resolver = new  SimpleMappingExceptionResolver();
       Properties mappings = new Properties();
       /**
        * 参数一:异常的类型,注意必须是异常类型的全名
        * 参数二:逻辑视图名称
        */
       mappings.put("java.lang.ArithmeticException", "error1");
       mappings.put("java.lang.NullPointerException", "error2");
       //设置异常与视图映射信息的
       resolver.setExceptionMappings(mappings);
       return resolver;
  }
}

 

三、SpringBoot定时任务

Scheduled 定时任务器:是 Spring3.0 以后自带的一个定时任务器

1、 引入依赖


<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>

2、编写定时任务


@Component
public class ScheduledDemo {

   /**
    *定时任务方法
    * @Scheduled:设置定时任务 cron 属性:cron 表达式。定时任务触发是时间的一个字符串表达形式
    */
   @Scheduled(cron = "0/2 * * * * ?")
   //@Scheduled(initialDelay = 1000 * 10,fixedRate = 1000 * 5) //fixedRate = 1000 *5表示每5秒执行一次
   public void scheduledMethod() {
       System.out.println("定时器被触发" + new Date());
  }
}

3、 开启定时任务注解

在启动类中添加@EnableScheduling注解


/**
* 启动类
*/
@SpringBootApplication
@MapperScan("cn.woniu.dao")//扫描dao
@EnableScheduling //开启定时任务
public class ApplicationApp {
   public static void main(String[] args) {
       SpringApplication.run(ApplicationApp.class,args);
  }
}

4、Cron 表达式


Cron 表达式是一个字符串,分为 6 或 7 个域,每一个域代表一个含义;
Cron 从左到右(用空格隔开): 秒   分   小时   月份中的日期   月份   星期中的日期   年份

Cron 有如下两种语法格式:

  • Seconds Minutes Hours Day Month Week Year

  • Seconds Minutes Hours Day Month Week

序号说明取值表达式
1 0-59 -*/
2 分钟 0-59 -*/
3 小时 0-23 -*/
4 1-31 -*/LWC
5 1-12 -*/
6 星期 1-7 -*?/LC#
7 年(可选) 1970-2099 -*/

Cron 表达式的时间字段除允许设置数值外,还可使用一些特殊的字符,提供列表、范围、通配符等功,如下:

  • 星号(*):可用在所有字段中,表示对应时间域的每一个时刻,例如,在分钟字段时,表示“每分钟”;

  • 问号(?):该字符只在日期和星期字段中使用,它通常指定为“无意义的值”,相当于占位符;

  • 减号(-):表达一个范围,如在小时字段中使用“10-12”,则表示从 10 到 12 点,即 10,11,12;

  • 逗号(,):表达一个列表值,如在星期字段中使用“MON,WED,FRI”,则表示星期一,星期三和星期五;

  • 斜杠(/):x/y 表达一个等步长序列,x 为起始值,y 为增量步长值。如在分钟字段中使用 0/15,则表示为 0,15,30 和 45 秒,而 5/15 在分钟字段中表示 5,20,35,50,你也可以使用*/y,它等同于 0/y;

  • L:该字符只在日期和星期字段中使用,代表“Last”的意思,但它在两个字段中意思不同。L 在日期字段中,表示这个月份的最后一天,如一月的 31 号,非闰年二月的 28 号;如果 L 用在星期中,则表示星期六,等同于 7。但是,如果 L 出现在星期字段里,而且在前面有一个数值 X,则表示“这个月的最后 X 天”,例如,6L 表示该月的最后星期五;

  • W:该字符只能出现在日期字段里,是对前导日期的修饰,表示离该日期最近的工作日。例如 15W表示离该月 15 号最近的工作日,如果该月 15 号是星期六,则匹配 14 号星期五;如果 15 日是星期日,则匹配 16 号星期一;如果 15 号是星期二,那结果就是 15 号星期二。但必须注意关联的匹配日期不能够跨月,如你指定 1W,如果 1 号是星期六,结果匹配的是 3 号星期一,而非上个月最后的那天。W 字符串只能指定单一日期,而不能指定日期范围;

  • LW 组合:在日期字段可以组合使用 LW,它的意思是当月的最后一个工作日;

  • 井号(#):该字符只能在星期字段中使用,表示当月某个工作日。如 6#3 表示当月的第三个星期五(6表示星期五,#3 表示当前的第三个),而 4#5 表示当月的第五个星期三,假设当月没有第五个星期三,忽略不触发;

  • C:该字符只在日期和星期字段中使用,代表“Calendar”的意思。它的意思是计划所关联的日期,如果日期没有被关联,则相当于日历中所有日期。例如 5C 在日期字段中就相当于日历 5 日以后的第一天。1C 在星期字段中相当于星期日后的第一天。

案例说明:


@Scheduled(cron = "0 0 1 1 1 ?")//每年一月的一号的 1:00:00 执行一次
@Scheduled(cron = "0 0 1 1 1,6 ?") //一月和六月的一号的 1:00:00 执行一次
@Scheduled(cron = "0 0 1 1 1,4,7,10 ?") //每个季度的第一个月的一号的 1:00:00 执行一次
@Scheduled(cron = "0 0 1 1 * ?")//每月一号 1:00:00 执行一次
@Scheduled(cron="0 0 1 * * *") //每天凌晨 1 点执行一次

 

四、SpringBoot热部署

SpringBoot执部署可以让程序员修改代码后不重新启动服务器也能访问到更新后的内容。

springboot热部署有两种方式:SpringLoader 插件、DevTools 工具;

1、使用 SpringLoader 进行项目热部署

在 pom文件中添加插件配置

如果在插件中无法加载可以现在pom的dependencies中下载后再在插件中引入依赖


<build>
       <plugins>
           <!-- springloader 插件 -->
           <plugin>
               <groupId>org.springframework.boot</groupId>
               <artifactId>spring-boot-maven-plugin</artifactId>
               <dependencies>
                   <dependency>
                       <groupId>org.springframework</groupId>
                       <artifactId>springloaded</artifactId>
                       <version>1.2.8.RELEASE</version>
                   </dependency>
               </dependencies>
           </plugin>
       </plugins>
   </build>

在主启动类中,右键以debug模式启动项目,访问/show路径,项目跳转到index页面,修改/show方法返回的值为“test”并且按 Ctr+shift+F9重新编译文件,刷新页面,发现没有重新启动项目也可以访问到修改后的内容

2、DevTools 工具

a、SpringLoader 与 DevTools 的区别

  • SpringLoader:SpringLoader 在部署项目时使用的是热部署的方式

  • DevTools:DevTools 在部署项目时使用的是重新部署的方式

修改pom


<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-devtools</artifactId>
</dependency>

b、修改idel 配置

file---Settings

 

 

ctr+alt+shift+"/"

 

 

启动项目后发现修改后可以不用手动重新启动项目就可以看到修改后的变化

posted on 2021-10-15 18:37  迎着风跑  阅读(1097)  评论(0编辑  收藏  举报