springboot笔记之helloworld

开发工具:IDEA 2019

springboot版本:2.1.9

一、springboot2.x VS 1.x

基础环境升级

  • 最低 JDK 8,支持 JDK 9,不再支持 Java 6 和 7


依赖组件升级

  • Spring Boot 2.0 基于 Spring Framework 5 构建,同时也升级了部分其依赖的第三方组件:
  • Jetty 9.4
  • Tomcat 8.5
  • Flyway 5
  • Hibernate 5.2
  • Gradle 3.4
  • Thymeleaf 3.0


默认软件替换和优化

  • HikariCP:默认连接池已从 Tomcat 切换到 HikariCP,HikariCP 是一个高性能的 JDBC 连接池
  • OAuth 2.0:Spring Boot 2.0 将 Spring Security OAuth 项目迁移到 Spring Security。不再提供单独的依赖包,通过 Spring Security 5 提供 OAuth 2.0 客户端支持.
  • Redis 默认使用 Lettuce


测试

  • 对 Spring Boot 2.0 中测试进行了一些补充和调整;
  • @WebFluxTest 已添加新注释以支持 WebFlux 应用程序的“slice”测试。
  • Converter 和 GenericConverter beans 现在自动扫描 @WebMvcTest 和 @WebFluxTest。
  • @AutoConfigureWebTestClient 已经添加到 WebTestClient 供测试使用,这个注释会自动应用于 @WebFluxTest 测试。
  • 增加了一个新的 ApplicationContextRunner 测试实用程序,可以很容易地测试你的自动配置,我们已将大部分内部测试套件移至此新模型。

新技术的引入

  • 支持 HTTP/2
  • 嵌入式 Netty 服务器
  • Kotlin 的支持
  • JOOQ 的支持
  • 支持 Quartz
  • 响应式编程

二、hello-world

   利用IDEA工具创建springboot工程:springboot-demo

 pom.xml文件添加依赖
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>

 

编写 Controller 内容创建 HelloController

@RestController
public class HelloController {

  @RequestMapping("/hello")
  public String hello() {
    return "hello world";
  }

}

运行启动类:DemoApplication

浏览器访问:http://localhost:8080/hello ,页面展示 hello world 。

 

三、自定义filter

Spring Boot 内置了一些 Filter,
比如,处理编码的 OrderedCharacterEncodingFilter 和请求转化的 HiddenHttpMethodFilter,也支持根据我们的需求来可以自定义 Filter。

自定义 Filter 有两种实现方式:(推荐使用第二个方案)
第一种是使用 @WebFilter,
第二种是使用 FilterRegistrationBean


以第二种为例:
1、实现 Filter 接口,实现其中的 doFilter() 方法;
public class MyFilter implements Filter {
  public void init(){}

  public void doFilter(ServletRequest request,ServletResponse ServletResponse,FilterChain chain){}

  public void destroy(){}
}

2、添加 @Configuration 注解,将自定义 Filter 加入过滤链。

@Configuration
public class WebConfiguration {

@Bean
FilterRegistrationBean filterRegistrationBean(){
  FilterRegistrationBean registrationBean = new FilterRegistrationBean();
  registrationBean.setFilter(new MyFilter());
  registrationBean.addUrlPatterns("/*");
  registrationBean.setName("MyFilter");
  //当有多个过滤器时可以通过设置 Order 属性来决定它
  registrationBean.setOrder(6);
  return registrationBean;
}
}

 

四、读取配置文件两种方式:

在 application.properties 中自定义配置:

demo.name=xxxxx

从配置文件加载单个配置内容时:

1、在注入的字段上使用注解 @Value 即可

@Value("${demo.name}")
private String name;

2、定义对象接受多个配置项
class类上使用注解 @ConfigurationProperties (prefix="demo") 列如:

@Component
@ConfigurationProperties (prefix="demo")
public class Demo{

private String name;

}
表示以 demo 开头的属性会自动赋值到对象的属性中,比如,demo.name 会自动赋值到对象属性 name 中

 

 

五、自定义配置文件:


  1、在 resources 目录下创建一个 my.properties 文件
  my.name=test
  my.password=test

2、定义对象接受配置项
类上使用注解 @PropertySource("classpath:my.properties") 读取配置文件

@Component
@ConfigurationProperties(prefix = "my")
@PropertySource("classpath:my.properties")
public class MyProperties {

private String name;
private String password;
//省略setter getter
}

 

posted @ 2019-09-22 17:40  2020持之以恒  阅读(228)  评论(0编辑  收藏  举报